位置: 编程技术 - 正文

python模拟登录并且保持cookie的方法详解(python模拟用户登录过程,输入账号及密码)

编辑:rootadmin

推荐整理分享python模拟登录并且保持cookie的方法详解(python模拟用户登录过程,输入账号及密码),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:用python模拟用户登录,python模拟app登录,python模拟用户登录过程,输入账号及密码,python模拟登陆并抓取,python 模拟登录,用python模拟用户登录,python 模拟登录,python 模拟登录,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

最近在爬行 nosec.org 的数据,看了下需要模拟登录拿到cookie后才能访问想抓的数据,重要的是 nosec.org 的登录页面 form 中有个 authenticity_token 字段每次访问登录页面都会自动生成,而且会和你的用户名,密码一样被POST到服务器。

经过一番研究后发现,直接访问网站登录界面的时候,服务器的响应头会有一个Set-Cookie字段,如下:

而且页面form 的表单有一个 authenticity_token 的 input ,内容如下:

python模拟登录并且保持cookie的方法详解(python模拟用户登录过程,输入账号及密码)

之前按照后端的逻辑分析_nosec_session 的值 经过解密以及各种xx手法得到 authenticity_token 的值,然后顺带着 username 和 password post就行了,最后发现这真是一个大写的傻逼!! 老是用后端的思维思考问题,过不得最近走路都走不好了。所以来,直接在页面中抓取已经生成的 authenticity_token 的值,然后 顺着 POST 过去就好了啊。

使用 requests 库 的 Session() 方法,确实很好用,比早期直接拿 cookielib 就干方便多了。

代码

类XXX 的 login 方法用来模拟登录,就贴出这部分登录的代码好了。

调用了 login 方法后 下次直接用self.s.get() 请求网页就会带着 cookie 啦。

之前被思路坑了一次,被笔误也坑了一次(https 写成 http),导致我抓狂了好久才发现这个 “BUG” = =、所以还得多谢 代码,提高排 Bug 的效率 !

总结

本文链接地址:https://www.jiuchutong.com/biancheng/377192.html 转载请保留说明!

上一篇:python 容器总结整理(python容错)

下一篇:python 遍历字符串(含汉字)实例详解(python 遍历字符串修改)

免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

鄂ICP备2023003026号

网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

友情链接: 武汉网站建设 电脑维修 湖南楚通运网络