Python中的CURL替代方案

Gau*_*rma 114 python curl

我有一个在PHP中使用的cURL调用:

curl -i -H'接受:application/xml'-u login:key" https://app.streamsend.com/emails "

我需要一种在Python中做同样事情的方法.在Python中是否有替代cURL的方法.我知道urllib,但我是一个Python noob,不知道如何使用它.

小智 133

您可以使用Requests:HTTP for Humans用户指南中描述的HTTP请求.

  • 请求是最新最好的!它抽烟并烧掉笨拙的urllib2,我希望请求成为python传入3.x版本的标准HTTP客户端 (2认同)

blw*_*y10 68

import urllib2

manager = urllib2.HTTPPasswordMgrWithDefaultRealm()
manager.add_password(None, 'https://app.streamsend.com/emails', 'login', 'key')
handler = urllib2.HTTPBasicAuthHandler(manager)

director = urllib2.OpenerDirector()
director.add_handler(handler)

req = urllib2.Request('https://app.streamsend.com/emails', headers = {'Accept' : 'application/xml'})

result = director.open(req)
# result.read() will contain the data
# result.info() will contain the HTTP headers

# To get say the content-length header
length = result.info()['Content-Length']
Run Code Online (Sandbox Code Playgroud)

您的cURL调用使用urllib2代替.完全未经测试.

  • 很高兴将它与下面的答案进行比较,看看Python在过去四年中取得了多大进展 (4认同)

bra*_*sch 35

这是一个使用urllib2的简单示例,它对GitHub的API进行基本身份验证.

import urllib2

u='username'
p='userpass'
url='https://api.github.com/users/username'

# simple wrapper function to encode the username & pass
def encodeUserData(user, password):
    return "Basic " + (user + ":" + password).encode("base64").rstrip()

# create the request object and set some headers
req = urllib2.Request(url)
req.add_header('Accept', 'application/json')
req.add_header("Content-type", "application/x-www-form-urlencoded")
req.add_header('Authorization', encodeUserData(u, p))
# make the request and print the results
res = urllib2.urlopen(req)
print res.read()
Run Code Online (Sandbox Code Playgroud)

此外,如果您将其包装在脚本中并从终端运行它,您可以将响应字符串传递给'mjson.tool'以启用漂亮的打印.

>> basicAuth.py | python -mjson.tool
Run Code Online (Sandbox Code Playgroud)

最后要注意的是,urllib2仅支持GET和POST请求.
如果你需要使用其他HTTP动词,如DELETE,PUT等,你可能想看看PYCURL


unh*_*ler 20

如果你使用一个命令只是像这样调用curl,你可以用Python做同样的事情subprocess.例:

subprocess.call(['curl', '-i', '-H', '"Accept: application/xml"', '-u', 'login:key', '"https://app.streamsend.com/emails"'])
Run Code Online (Sandbox Code Playgroud)

或者你可以试试PycURL,如果你想把它作为一个更像PHP的结构api.


tad*_*cks 12

import requests

url = 'https://example.tld/'
auth = ('username', 'password')

r = requests.get(url, auth=auth)
print r.content
Run Code Online (Sandbox Code Playgroud)

这是我能够得到的最简单的.


Rei*_*hin 7

一些例子,如何使用urllib来处理那些事情,并使用一些糖语法.我知道请求和其他库,但urllib是python的标准库,不需要单独安装任何东西.

Python 2/3兼容.

import sys
if sys.version_info.major == 3:
  from urllib.request import HTTPPasswordMgrWithDefaultRealm, HTTPBasicAuthHandler, Request, build_opener
  from urllib.parse import urlencode
else:
  from urllib2 import HTTPPasswordMgrWithDefaultRealm, HTTPBasicAuthHandler, Request, build_opener
  from urllib import urlencode


def curl(url, params=None, auth=None, req_type="GET", data=None, headers=None):
  post_req = ["POST", "PUT"]
  get_req = ["GET", "DELETE"]

  if params is not None:
    url += "?" + urlencode(params)

  if req_type not in post_req + get_req:
    raise IOError("Wrong request type \"%s\" passed" % req_type)

  _headers = {}
  handler_chain = []

  if auth is not None:
    manager = HTTPPasswordMgrWithDefaultRealm()
    manager.add_password(None, url, auth["user"], auth["pass"])
    handler_chain.append(HTTPBasicAuthHandler(manager))

  if req_type in post_req and data is not None:
    _headers["Content-Length"] = len(data)

  if headers is not None:
    _headers.update(headers)

  director = build_opener(*handler_chain)

  if req_type in post_req:
    if sys.version_info.major == 3:
      _data = bytes(data, encoding='utf8')
    else:
      _data = bytes(data)

    req = Request(url, headers=_headers, data=_data)
  else:
    req = Request(url, headers=_headers)

  req.get_method = lambda: req_type
  result = director.open(req)

  return {
    "httpcode": result.code,
    "headers": result.info(),
    "content": result.read()
  }


"""
Usage example:
"""

Post data:
  curl("http://127.0.0.1/", req_type="POST", data='cascac')

Pass arguments (http://127.0.0.1/?q=show):
  curl("http://127.0.0.1/", params={'q': 'show'}, req_type="POST", data='cascac')

HTTP Authorization:
  curl("http://127.0.0.1/secure_data.txt", auth={"user": "username", "pass": "password"})
Run Code Online (Sandbox Code Playgroud)

功能不完整,可能不理想,但显示了使用的基本表示和概念.其他东西可以根据口味添加或改变.

12/08更新

是一个GitHub链接到实时更新源.目前支持:

  • 授权

  • CRUD兼容

  • 自动字符集检测

  • 自动编码(压缩)检测


stu*_*ing 5

如果它从您正在寻找的命令行运行上述所有内容,那么我建议使用HTTPie。这是一个奇妙的卷曲替代品,超级容易方便,以使用(和定制)。

这是来自 GitHub 的(简洁而准确的)描述;

HTTPie(读作 aych-tee-tee-pie)是一个命令行 HTTP 客户端。它的目标是使 CLI 与 Web 服务的交互尽可能人性化。

它提供了一个简单的 http 命令,允许使用简单自然的语法发送任意 HTTP 请求,并显示彩色输出。HTTPie 可用于测试、调试以及与 HTTP 服务器的一般交互。


有关身份验证的文档应该为您提供足够的指示来解决您的问题。当然,以上所有答案也是准确的,并提供了完成相同任务的不同方法。


只是为了让您不必远离 Stack Overflow,这就是它提供的简而言之。

Basic auth:

$ http -a username:password example.org
Digest auth:

$ http --auth-type=digest -a username:password example.org
With password prompt:

$ http -a username example.org
Run Code Online (Sandbox Code Playgroud)