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 MySQLdb Windows下安装教程及问题解决方法
May 09 Python
基于Python_脚本CGI、特点、应用、开发环境(详解)
May 23 Python
Python numpy生成矩阵、串联矩阵代码分享
Dec 04 Python
PyQt5每天必学之关闭窗口
Apr 19 Python
使用Selenium破解新浪微博的四宫格验证码
Oct 19 Python
Python基础知识点 初识Python.md
May 14 Python
python-tkinter之按钮的使用,开关方法
Jun 11 Python
python+logging+yaml实现日志分割
Jul 22 Python
python识别文字(基于tesseract)代码实例
Aug 24 Python
tensorflow 保存模型和取出中间权重例子
Jan 24 Python
Python简单实现词云图代码及步骤解析
Jun 04 Python
Python中Selenium模块的使用详解
Oct 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 采集程序原理分析篇
2010/03/05 PHP
PHP中使用jQuery+Ajax实现分页查询多功能操作(示例讲解)
2017/09/17 PHP
javascript js cookie的存储,获取和删除
2007/12/29 Javascript
Knockoutjs快速入门(经典)
2012/12/24 Javascript
javascript如何动态加载表格与动态添加表格行
2013/11/27 Javascript
jquery插件corner实现圆角边框的方法
2015/03/09 Javascript
JavaScript通过select动态更换图片的方法
2015/03/23 Javascript
jQuery自定义动画函数实例详解(附demo源码)
2015/12/10 Javascript
你所未知的3种Node.js代码优化方式
2016/02/25 Javascript
原生js获取元素样式的简单方法
2016/08/06 Javascript
javascript使用递归算法求两个数字组合功能示例
2017/01/03 Javascript
JS如何设置元素样式的方法示例
2017/08/28 Javascript
Vue渲染函数详解
2017/09/15 Javascript
JavaScript函数IIFE使用详解
2019/10/21 Javascript
Javascript执行流程细节原理解析
2020/05/14 Javascript
王纯业的Python学习笔记 下载
2007/02/10 Python
Python的Django框架中的select_related函数对QuerySet 查询的优化
2015/04/01 Python
从局部变量和全局变量开始全面解析Python中变量的作用域
2016/06/16 Python
Python中的字符串替换操作示例
2016/06/27 Python
Python实现嵌套列表去重方法示例
2017/12/28 Python
PyCharm鼠标右键不显示Run unittest的解决方法
2018/11/30 Python
Python使用pydub库对mp3与wav格式进行互转的方法
2019/01/10 Python
Python判断对象是否相等及eq函数的讲解
2019/02/25 Python
Python 多线程搜索txt文件的内容,并写入搜到的内容(Lock)方法
2019/08/23 Python
tensorflow多维张量计算实例
2020/02/11 Python
网易微博Web App用HTML5开发的过程介绍
2012/06/13 HTML / CSS
菲律宾购物网站:Lazada菲律宾
2018/04/05 全球购物
Java中各种基本数据类型的默认值都是什么
2016/12/22 面试题
编辑找工作求职信范文
2013/12/16 职场文书
2015年九一八事变纪念日演讲稿
2015/03/19 职场文书
大学生就业意向书
2015/05/11 职场文书
2015年学校党建工作总结
2015/05/19 职场文书
游戏开发中如何使用CocosCreator进行音效处理
2021/04/14 Javascript
pytorch 如何使用amp进行混合精度训练
2021/05/24 Python
缓存替换策略及应用(以Redis、InnoDB为例)
2021/07/25 Redis
MySQL数据库之内置函数和自定义函数 function
2022/06/16 MySQL