Python 中的 CURL 替代品

问题描述 投票:0回答:7

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

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

我需要一种方法在 Python 中做同样的事情。 Python 中有 cURL 的替代品吗?我知道 urllib 但我不知道如何使用它。

python curl
7个回答
136
投票

您可以使用Requests库。安装它

pip install requests

您可以在 https://requests.readthedocs.io/en/latest/

找到其文档

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']

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


36
投票

这是一个使用 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()

此外,如果您将其包装在脚本中并从终端运行它,您可以将响应字符串通过管道传输到“mjson.tool”以启用漂亮的打印。

>> basicAuth.py | python -mjson.tool

最后要注意的一点是,urllib2 仅支持 GET 和 POST 请求。
如果您需要使用其他 HTTP 动词,例如 DELETE、PUT 等,您可能需要看看 PYCURL


20
投票

如果您使用命令来像这样调用curl,您可以在Python 中使用

subprocess
执行相同的操作。示例:

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

或者你可以尝试 PycURL 如果你想将它作为一个像 PHP 那样更加结构化的 api。


13
投票
import requests

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

r = requests.get(url, auth=auth)
print(r.content)

这是我能得到的最简单的。


7
投票

一些示例,如何使用 urllib 来完成这些事情,并使用一些糖语法。我了解 requests 和其他库,但 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"})

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

12/08更新

Here 是实时更新源代码的 GitHub 链接。 目前支持:

  • 授权

  • 兼容CRUD

  • 自动字符集检测

  • 自动编码(压缩)检测


4
投票

如果它从您正在寻找的命令行运行上述所有内容,那么我建议HTTPie。它是一个非常棒的 cURL 替代品,使用(和自定义)超级简单方便

这是来自 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

© www.soinside.com 2019 - 2024. All rights reserved.