この記事では主に Python のシミュレートされたログイン実装コードを紹介します。詳細なコードはここにまとめられています。興味のある方は参考にしてください。
以下は、Python を使用して Web サイトのログインをシミュレートする小さな例です。
原則
ウェブサイトのログイン認証をバイパスするためにCookieテクノロジーを使用します。 cookielib ライブラリを使用します。プロセス:
Cookie を保存するコンテナーを作成します。オプションは、CookieJar、FileCookieJar、MozillaCookieJar、および LWPCookieJar です。これらの関係は、CookieJar --- Derived --> MozillaCookieJar です。 LWPCookieJar.
次に、urllib2.HTTPCookieProcessor(cookie) を使用して、Web サイトを開くためのオープナーを作成します。それでおしまい。このオープナーは、urllib2.urlopen メソッドよりも一般的です。オープナー = urllib2.build_opener(ハンドラー)。
これで、オープナーを使用して通常通りネットワークにアクセスできるようになります。
実装された機能は、大連理工大学の教務ウェブサイトへのログインをシミュレートするものです。コードは次のとおりです。 # coding:UTF-8
import urllib,urllib2,cookielib
filename = r'F:\pachong\gaoqing\dlutcookie.txt'
# show cookie and save to local
cookie = cookielib.MozillaCookieJar()
handler = urllib2.HTTPCookieProcessor(cookie)
opener = urllib2.build_opener(handler)
# 记得使用urllib模块进行参数的encode
postdata = urllib.urlencode({
# 哈哈,本宫不给你们我的账号╭(╯^╰)╮
'zjh':'xxxxxxxxx',
'mm':'XXXXXX'
})
# 登陆到教务系统的url
url = 'http://zhjw.dlut.edu.cn/loginAction.do'
# 开始进行模拟登陆,并把cookie保存到变量
response = opener.open(url,postdata)
cookie.save(filename,ignore_discard=True,ignore_expires=True)
# 打印一下获得的cookie信息吧
for item in cookie:
item.name + ' = ' + item.value
# 利用cookie访问另一个网址 登陆到个人成绩的URL
course_url='zhjw.dlut.edu.cn/xkAction.do?actionType=6'
course_header={
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2486.0 Safari/537.36 Edge/13.10586',
'referer':'zhjw.dlut.edu.cn/menu/s_main.jsp'
}
result = opener.open(course_url)
print result.read()
概要
実際、シミュレートされたログインの場合、最初のログインは Cookie データを取得することです。次に、作成したオープナーを使用して、次に実行する主要なさらなる操作を完了します。理解する必要があるのは、Cookie を使用するプロセスだけです。
以上がPython模擬ログイン例の詳しい説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。