IDとパスワードを使用して大学のサイトにログインするPythonプログラムを作成しようとしています。これは、ログインするための正式なページです:https ://webapp.pucrs.br/consulta/
お気づきかもしれませんが、2つのフィールドの名前はpr1とpr2です。このページはPOSTを使用してデータを送信します。また、ページが読み込まれるときにダウンロードされるCookieがあります。これは、ランダムな値を含むJSESSIONIDであり、私が理解したように、ログインを認証するためにPOSTメソッドのヘッダーに戻る必要があります。
次のコードを記述しましたが、GETメソッドの戻りページに「セッションが初期化されていません」と表示されます。これは、Cookieが正しく返送されなかったことが原因である可能性があります。
from urllib2 import Request, build_opener, HTTPCookieProcessor, HTTPHandler
import httplib, urllib, cookielib, Cookie, os
conn = httplib.HTTPConnection('webapp.pucrs.br')
#COOKIE FINDER
cj = cookielib.CookieJar()
opener = build_opener(HTTPCookieProcessor(cj),HTTPHandler())
req = Request('http://webapp.pucrs.br/consulta/principal.jsp')
f = opener.open(req)
html = f.read()
for cookie in cj:
c = cookie
#FIM COOKIE FINDER
params = urllib.urlencode ({'pr1':111049631, 'pr2':<pass>})
headers = {"Content-type":"text/html",
"Set-Cookie" : "JSESSIONID=70E78D6970373C07A81302C7CF800349"}
# I couldn't set the value automaticaly here, the cookie object can't be converted to string, so I change this value on every session to the new cookie's value. Any solutions?
conn.request ("POST", "/consulta/servlet/consulta.aluno.ValidaAluno",params, headers) # Validation page
resp = conn.getresponse()
temp = conn.request("GET","/consulta/servlet/consulta.aluno.Publicacoes") # desired content page
resp = conn.getresponse()
print resp.read()
ログインが認証されるように、このCookieをどこに置くのですか?