Альтернатива CURL в Python
У меня есть вызов cURL, который я использую в PHP:
curl -i -H 'Accept: application/xml' -u login: key " https://app.streamsend.com/emails"
Мне нужен способ сделать то же самое в Python. Есть ли альтернатива cURL в Python. Я знаю urllib, но я Python noob и понятия не имею, как его использовать.
Ответы
Ответ 1
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. Полностью непроверенный.
Ответ 2
Вы можете использовать HTTP-запросы, описанные в руководстве Requests: HTTP for Humans.
Ответ 3
Вот простой пример использования urllib2, который выполняет базовую аутентификацию с API GitHub.
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()
Кроме того, если вы завернете это в script и запустите его с терминала, вы можете подключить строку ответа к 'mjson.tool', чтобы включить печать.
>> basicAuth.py | python -mjson.tool
Последнее, что нужно отметить, urllib2 поддерживает только запросы GET и POST.
Если вам нужно использовать другие HTTP-глаголы, такие как DELETE, PUT и т.д., Вы, вероятно, захотите взглянуть на PYCURL
Ответ 4
Если вы используете команду, чтобы просто вызвать завиток, вы можете сделать то же самое в Python с помощью subprocess
. Пример:
subprocess.call(['curl', '-i', '-H', '"Accept: application/xml"', '-u', 'login:key', '"https://app.streamsend.com/emails"'])
Или вы можете попробовать PycURL, если хотите, чтобы он был более структурированным api, как то, что имеет PHP.
Ответ 5
import requests
url = 'https://example.tld/'
auth = ('username', 'password')
r = requests.get(url, auth=auth)
print r.content
Это самое простое, что я смог получить.
Ответ 6
В некотором примере, как использовать urllib для этого, с синтаксисом сахара. Я знаю о запросах и других библиотеках, но urllib является стандартным lib для 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
Здесь - ссылка GitHub для обновления обновленного источника.
В настоящее время поддерживается:
Ответ 7
Если он выполнит все вышеперечисленное из командной строки, которую вы ищете, я бы рекомендовал HTTPie. Это фантастическая альтернатива cURL и очень проста и удобна в использовании (и настройке).
Вот его (краткое и точное) описание от GitHub;
HTTPie (произносится как aych-tee-tee-pie) - это HTTP-клиент командной строки. Его цель - сделать взаимодействие CLI с веб-сервисами как максимально удобен для людей.
Он предоставляет простую команду http, которая позволяет отправлять произвольные HTTP-запросы с использованием простого и естественного синтаксиса и отображения цветной выход. HTTPie может использоваться для тестирования, отладки и обычно взаимодействующих с серверами HTTP.
Документация вокруг authentication должна дать вам достаточно указателей для решения ваших проблем. Конечно, все ответы выше также точны и предоставляют разные способы решения одной и той же задачи.
Просто чтобы вам не пришлось уходить от 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