下面分享一个使用Python进行网站模拟登陆的小例子。
原理
使用Cookie技术,绕开网站登录验证。要使用到cookielib库。流程:
小案例
实现的功能是模拟登录到大连理工大学的教务网站。代码如下:
# 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='http://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':'http://zhjw.dlut.edu.cn/menu/s_main.jsp' } result = opener.open(course_url) print result.read()
运行结果
总结
其实对于模拟登陆而言,第一次的登陆就是为了获取那个cookie数据。然后通过我们创建的opener来完成接下来我们要进行的关键的进一步的操作。我们需要理解的就只是那个cookie的使用的流程就行了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。