httplib2を使用して Web ページにログインしようとしています。Chrome のシークレット ウィンドウで次の URL を開くだけで、ページにログインできます。
https://domain.com/auth?name=USERNAME&pw=PASSWORD
httplib2 でこのログインをエミュレートするために、次のコードを試しました。
from httplib2 import Http
h = Http(disable_ssl_certificate_validation=True)
resp, content = h.request('https://domain.com/auth?name=USERNAME&pw=PASSWORD')
残念ながら、このリクエストではログインは成功しません。
Chrome が提供するものと一致するようにリクエスト ヘッダーを変更してみました。
headers = {
'Host': 'domain.com',
'Connection': 'keep-alive',
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8',
'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/30.0.1599.101 Safari/537.36',
'Accept-Encoding': 'gzip,deflate,sdch',
'Accept-Language': 'en-US,en;q=0.8'
}
resp, content = h.request('https://domain.com/auth?name=USERNAME&pw=PASSWORD', 'GET', headers=headers)
これにより応答がわずかに変わりますが、それでもログインは成功しません。
実際のネットワーク トラフィックをWiresharkで調べてみましたが、HTTPS で暗号化されているため、実際のトラフィックはわかりません。
Chrome と httplib2 のリクエストの違いを知っている人はいますか? httplib2 がヘッダーの一部を変更するのではないでしょうか?