python模拟登录并且保持cookie的方法详解


Posted in Python onApril 04, 2017

前言

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

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

_nosec_session=ZTlHNmxuZXE4R0s1UXpsVUxGRTNPblNBWFd2TXU4TU9aNWVJM2lyLzNFY0pLeUdNMDY1cmZqanpkc0ppaGtjU
i9kTGdWenBrNXJKenNqbnN2YUxucE1DRW5UMHNTR1RxWDZPeGlLazllTmY1czVpYWplazJXdWkvZS9wUHJpc1Jya3ZzcmNVMytPR
it2T1dEcGx4bHNDTTVzSmVTb0xhSjRycE03QUl5RXE5Z2tZWG1mTHFBWGx1QW52QjBURi8rLS1acE8yeVRtMFRZR1JWdExneStwdmpRPT0
%3D--a6ccd9a12a8af5c8b5fb6625c24bb4db0398c503; path=/; HttpOnly

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

<input type="hidden" name="authenticity_token" value="cGdhqVxDMRndpKbpvIV66wfEQlGf4Rz6UtXqsf79brEvFveHw2rCc6uz3euFEyUlpuA0azt5uNhnmrUiCaAyUg==" />

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

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

代码

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

class XXX:
 def login(self):

  r = self.s.get('https://nosec.org/users/sign_in')
  html = r.text
  p1 = re.compile(r'city_token" value="(.*?)"')
  res = re.search(p1,html)
  authenticity_token = str(res.group(1))
  print 'authenticity_token:',authenticity_token
  # print 'cookies',self.s.cookies
  # print s.cookies
  data = {
   'authenticity_token':authenticity_token,
   'user[login]':'xxxxx',
   'user[password]':'xxxxx'
  }
  r = self.s.post('https://nosec.org/users/sign_in',data=data)
  # print r.headers
  # print r.request.headers
  # print self.s.cookies
  print '[*] OK!'
  return True

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

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
Python的ORM框架SQLAlchemy入门教程
Apr 28 Python
python创建和删除目录的方法
Apr 29 Python
Python实现数通设备端口使用情况监控实例
Jul 15 Python
Python实现的堆排序算法示例
Apr 29 Python
Python、 Pycharm、Django安装详细教程(图文)
Apr 12 Python
OpenCV 模板匹配
Jul 10 Python
python写入数据到csv或xlsx文件的3种方法
Aug 23 Python
Python3 中作为一等对象的函数解析
Dec 11 Python
你应该知道的Python3.6、3.7、3.8新特性小结
May 12 Python
浅谈tensorflow中dataset.shuffle和dataset.batch dataset.repeat注意点
Jun 08 Python
python3获取控制台输入的数据的具体实例
Aug 16 Python
Cpython解释器中的GIL全局解释器锁
Nov 09 Python
python 容器总结整理
Apr 04 #Python
详解Python中最难理解的点-装饰器
Apr 03 #Python
JSON Web Tokens的实现原理
Apr 02 #Python
Python 40行代码实现人脸识别功能
Apr 02 #Python
Python可变参数用法实例分析
Apr 02 #Python
Python编程实现数学运算求一元二次方程的实根算法示例
Apr 02 #Python
Python中selenium实现文件上传所有方法整理总结
Apr 01 #Python
You might like
php计算两个坐标(经度,纬度)之间距离的方法
2015/04/17 PHP
使用PHPStorm+XDebug搭建单步调试环境
2017/11/19 PHP
JavaScript Undefined,Null类型和NaN值区别
2008/10/22 Javascript
Js 中debug方式
2010/02/07 Javascript
通过DOM脚本去设置样式信息
2010/09/19 Javascript
JavaScript单元测试ABC
2012/04/12 Javascript
setTimeout()递归调用不加引号出错的解决方法
2014/09/05 Javascript
JavaScript版的TwoQueues缓存模型
2014/12/29 Javascript
移动开发之自适应手机屏幕宽度
2016/11/23 Javascript
详解基于 Nuxt 的 Vue.js 服务端渲染实践
2017/10/24 Javascript
Vue+Jwt+SpringBoot+Ldap完成登录认证的示例代码
2018/05/21 Javascript
Vue框架里使用Swiper的方法示例
2018/09/20 Javascript
详解ES6 系列之异步处理实战
2018/10/26 Javascript
vue计算属性computed、事件、监听器watch的使用讲解
2019/01/21 Javascript
详解vue-property-decorator使用手册
2019/07/29 Javascript
vue实现抖音时间转盘
2019/09/08 Javascript
JS手写一个自定义Promise操作示例
2020/03/16 Javascript
微信小程序实现加入购物车滑动轨迹
2020/11/18 Javascript
python利用paramiko连接远程服务器执行命令的方法
2017/10/16 Python
Python读取YUV文件,并显示的方法
2018/12/04 Python
python enumerate内置函数用法总结
2020/01/07 Python
Python基于tkinter canvas实现图片裁剪功能
2020/11/05 Python
美国批发零售网站:GearXS
2016/07/26 全球购物
TOWER London官网:鞋子、靴子、运动鞋等
2019/07/14 全球购物
毕业生自荐书
2014/02/03 职场文书
《从现在开始》教学反思
2014/04/15 职场文书
小学生国庆演讲稿
2014/09/05 职场文书
物流管理专业推荐信
2014/09/06 职场文书
大学运动会加油稿200字(5篇)
2014/09/27 职场文书
常务副总经理岗位职责
2015/02/02 职场文书
2015年安置帮教工作总结
2015/05/22 职场文书
如何用JavaScript实现一个数组惰性求值库
2021/05/05 Javascript
忘记Grafana不要紧2种Grafana重置admin密码方法详细步骤
2022/04/07 Servers
PostgreSQL数据库创建并使用视图以及子查询
2022/04/11 PostgreSQL
第四次工业革命,打工人与机器人的竞争
2022/04/21 数码科技
Golang入门之计时器
2022/05/04 Golang