使用Python爬虫怎么实现验证码登录?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
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")
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。