14

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をどこに置くのですか?

4

5 に答える 5

23

ライブラリを使ってみrequestsます。ドキュメントは素晴らしく、コードは最終的にはよりクリーンになりますurllib*

$ pip install requests

独自にCookieを処理するセッション(Piotrによるコメントを参照)を使用すると、結果は次のようになります。

import requests
url_0 = "http://webapp.pucrs.br/consulta/principal.jsp"
url = "https://webapp.pucrs.br/consulta/servlet/consulta.aluno.ValidaAluno"
data = {"pr1": "123456789", "pr2": "1234"}

s = requests.session()
s.get(url_0)
r = s.post(url, data)

pr1123456789の「Usuarioinexistente」とユーザー番号の「Sehnainválida 」の通知が届くので、問題なく動作しているようです。

于 2012-04-20T14:37:54.367 に答える
7

すべてのリクエストに対して作成したものと同じ「オープナー」を使用する必要があります。これにより、Cookieがすべて単独で処理されます。

これは私が最近書いたものの抜粋です

opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(cookielib.CookieJar()))

# then for all requests

if postData:     
    pData =  urllib.urlencode(postData)
else:
    pData = None

httpReq = urllib2.Request(url, pData, self._headers)
page =  opener.open(httpReq)
于 2012-04-20T14:44:55.980 に答える
5

MatthieuWの回答をPython3に変換すると次のようになります。

import urllib, http.cookiejar

opener = urllib.request.build_opener(urllib.request.HTTPCookieProcessor(http.cookiejar.CookieJar()))
# then for all requests

if postData:     
    pData =  urllib.parse.urlencode(postData)
else:
    pData = None

httpReq = urllib.request.Request(url, pData)
page =  opener.open(httpReq)
于 2013-06-17T18:19:25.170 に答える
1

mechanizeを使用することをお勧めします。これにより、セッション/ Cookie /ログインが自動的に処理されます。さらに、urllibのようなAPIやフォーム入力などが提供されるため、適切なPOSTリクエストをいじる必要はありません。 mechanizeによって構築されました。

于 2012-04-20T13:24:01.600 に答える
1

urllibは良くありません、リクエストを使用してください!

from requests import Request, Session

url = "https://webapp.pucrs.br/consulta/principal.jsp"
s = requests.Session()

p = dict(pb1 = 'dd', pb2 = 'cc')
r = s.get(url, params = p) 
# use the cert=/path/to/certificate.pem if you need it
# elsewhere use verify = False to bypass ssl verification

c = r.cookies

# Then send back a response using those same cookies

r = requests.get(other_url, cookies = c, verify = False)
于 2014-01-07T09:35:12.230 に答える