1

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 がヘッダーの一部を変更するのではないでしょうか?

4

1 に答える 1

1

Games Brainiac のコメントに続いて、私は単にPython Requestsの代わりにhttplib2. 次のrequestsコードはそのまま使用できます。

import requests
session = requests.Session()
response = session.get('https://domain.com/auth?name=USERNAME&pw=PASSWORD')

Session同じユーザー名/パスワードを使用した追加のリクエストは、オブジェクトに対して簡単に実行できます。

...
next_response = session.get('https://domain.com/someOtherPage')
于 2013-10-24T14:43:19.103 に答える