Pythonの基本認証でHTTP POSTを実行する最もクリーンな方法は何ですか?
Pythonコアライブラリのみを使用します。
真剣に、単に requests
を使用してください:
import requests
resp = requests.post(url, data={}, auth=('user', 'pass'))
純粋なpythonライブラリです。インストールはeasy_install requests
またはpip install requests
。非常にシンプルで使いやすいAPIを備えており、urllib2
あなたがする必要はありません。愚かな自己課せられた要件のためにあなたの人生を難しくしないでください。
ハックの回避策は動作します:
urllib.urlopen("https://username:password@hostname/path", data)
多くの人は、URLでユーザー名とパスワードを指定する古い構文がurllib.urlopen
。パスワードに「@」記号が含まれている場合を除き、ユーザー名またはパスワードにエンコードが必要なようには見えません。
uRL、ユーザー名、パスワード、およびいくつかのポストデータを定義する場合、これはPython2で動作するはずです...
import urllib2
passman = urllib2.HTTPPasswordMgrWithDefaultRealm()
passman.add_password(None, url, username, password)
auth_handler = urllib2.HTTPBasicAuthHandler(passman)
opener = urllib2.build_opener(auth_handler)
urllib2.install_opener(opener)
content = urllib2.urlopen(url, post_data)
公式の例Python urllib2で基本認証を示すドキュメント:* http://docs.python.org/release/2.6/howto/urllib2.html
urllib2を使用した基本認証の完全なチュートリアル:* http://www.voidspace.org.uk/python/articles/authentication.shtml