Python爬虫实现验证码登录代码实例
很多网站为了避免被恶意访问,需要设置验证码登录,避免非人类的访问,Python爬虫实现验证码登录的原理则是先到登录页面将生成的验证码保存下来,然后人为输入后,包装后再POST给服务器,实现验证,这里还涉及到了Cookie,其实Cookie保存在本地主机上,避免用户重复输入用户名和密码,在连接服务器的时候将访问连接和Cookie组装起来POST给服务器。
这里涉及到了两次向服务器POST,一次是Cookie,这里还自行设计想要Cookie的内容,由于是要登录,Cookie中存放的则是用户名和密码。第二次POST则是向服务器提交验证。
这里用到Python3,主要用到的包是re urllib.request http.cookiejar
上代码,借鉴了别人的代码~~~
import re import urllib.request import http.cookiejar #from http.comkie import CookieJar 上面那句和这句等同 loginurl='https://www.douban.com/accounts/login' cookie = http.cookiejar.CookieJar() opener = urllib.request.build_opener(urllib.request.HTTPCookieProcessor)#在已存的Cookie下建立连接 params={} params['form_email']='用户名' params['form_password']='密码'#这里写上已有的用户名和密码 params['source']='http://www.douban.com/accounts/login' #从首页提交登陆 response = opener.open(loginurl,urllib.parse.urlencode(params).encode('utf-8'))#urllib.parse.urlencode(params).encode('utf-8')这个是向服务 #器POST的内容,可以打印一下response.geturl()请求的连接看一下 #print(response.geturl()[0:33]) #验证成功跳转至登陆页 if response.geturl()[0:33]=='https://accounts.douban.com/login': html = response.read().decode('utf-8') #print(html),可以先打印一下文件内容,为了看到网页元素更方便的写正则,可以复制下来,在需要获取的地方用(.+?)表示,然后用group()元组来取得, #验证图片地址 imgurl=re.search('<img id="captcha_image" src="(.+?)" alt="captcha" class="captcha_image"/>',html) if imgurl: url=imgurl.group(1) #print(url) #将验证码以v.jpg保存在本地,在输入验证码的时候可以手工输入 res=urllib.request.urlretrieve(url,'v.jpg') captcha = re.search('<input type="hidden" name="captcha-id" value="(.+?)"/>',html) #print(captcha.group(1)) if captcha: vcode=input('请输入图片上的验证码:') params["captcha-solution"] = vcode params["captcha-id"] = captcha.group(1)#这个是动态生成的,需要从网页中获得 params["user_login"] = "登录" #提交验证码验证 response = opener.open(loginurl,urllib.parse.urlencode(params).encode('utf-8')) if response.geturl()=="https://www.douban.com/": print("login sucess")
以上所述是小编给大家介绍的Python爬虫实现验证码登录详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
- 用Python爬虫破解滑动验证码的案例解析
- python网络爬虫实现发送短信验证码的方法
- Python爬虫爬取ts碎片视频+验证码登录功能
- python爬虫如何解决图片验证码
- Python爬虫模拟登陆哔哩哔哩(bilibili)并突破点选验证码功能
- Python3爬虫里关于识别微博宫格验证码的知识点详解
- Python3爬虫关于识别点触点选验证码的实例讲解
- Python3爬虫关于识别检验滑动验证码的实例
- Python3爬虫中识别图形验证码的实例讲解
- Python3网络爬虫开发实战之极验滑动验证码的识别
- python爬虫解决验证码的思路及示例
- python爬虫之验证码篇3-滑动验证码识别技术
- python爬虫之自动登录与验证码识别
- Python爬虫爬验证码实现功能详解
- Python爬虫模拟登录带验证码网站
- 爬虫Python验证码识别入门
相关文章
Python HTMLTestRunner可视化报告实现过程解析
这篇文章主要介绍了Python HTMLTestRunner可视化报告实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2020-04-04在pycharm中关掉ipython console/PyDev操作
这篇文章主要介绍了在pycharm中关掉ipython console/PyDev操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-06-06Django模板标签中url使用详解(url跳转到指定页面)
这篇文章主要介绍了Django模板标签中url使用详解(url跳转到指定页面),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-03-03
最新评论