简介
  有些登录的接口会有验证码:短信验证码,图形验证码等,这种登录的话验证码参数可以从后台获取的(或者查数据库最直接)。获取不到也没关系,可以通过添加cookie的方式绕过验证码。(注意:并不是所有的登录都是用cookie来保

持登录的,有些是用token登录)

抓登录cookie
1、如博客园登录后会生成一个已登录状态的cookie,那么只需要直接把这个值添加到cookies里面就可以了。

2、可以先手动登录一次,然后抓取这个cookie,这里就需要用抓包工具fiddler了

3、先打开博客园登录界面,手动输入账号和密码(勾选下次自动登录)


4、打开fiddler抓包工具,刷新下登录首页,就是登录前的cookie了


5、登录成功后,再查看cookie变化,发现多了两组参数,多的这两组参数就是我们想要的,copy出来,一会有用


cookie组成结构
1、用抓包工具fidller只能看到cookie的name和value两个参数,实际上cookie还有其它参数

2、以下是一个完整的cookie组成结构

cookie ={u’domain’: u’.cnblogs.com’,
u’name’: u’.CNBlogsCookie’,
u’value’: u’xxxx’,
u’expiry’: 1491887887,
u’path’: u’/’,
u’httpOnly’: True,
u’secure’: False}
name:cookie的名称

value:cookie对应的值,动态生成的

domain:服务器域名

expiry:Cookie有效终止日期

path:Path属性定义了Web服务器上哪些路径下的页面可获取服务器设置的Cookie

httpOnly:防脚本攻击

secure:在Cookie中标记该变量,表明只有当浏览器和Web Server之间的通信协议为加密认证协议时,

浏览器才向服务器提交相应的Cookie。当前这种协议只有一种,即为HTTPS。

添加cookie
1、往session里面添加cookie可以用以下方式

2、set里面参数按括号里面的参数格式

coo = requests.cookies.RequestsCookieJar()
coo.set(‘cookie-name’, ‘cookie-value’, path=’/’, domain=’.xxx.com’)
s.cookies.update©
3、于是添加登录的cookie,把第一步fiddler抓到的内容填进去就可以了

c = requests.cookies.RequestsCookieJar()
c.set(’.CNBlogsCookie’, ‘xxx’)
c.set(’.Cnblogs.AspNetCore.Cookies’,‘xxx’)
s.cookies.update©
print(s.cookies)

代码运行,刷新随笔
1、看到刚刚添加的随笔

参考代码
1、由于登录时候是多加2个cookie,我们可以先用get方法打开登录首页,获取部分cookie

2、再把登录需要的cookie添加到session里

3、添加成功后,随便编辑正文和标题保存到草稿箱

1 # coding:utf-8
2 import requests
3 # 先打开登录首页,获取部分cookie
4 url = “https://passport.cnblogs.com/user/signin”
5 headers = {
6 “User-Agent”: “Mozilla/5.0 (Windows NT 10.0; WOW64; rv:44.0) Gecko/20100101 Firefox/44.0”
7 } # get方法其它加个ser-Agent就可以了
8 s = requests.session()
9 r = s.get(url, headers=headers,verify=False)
10 print s.cookies
11 # 添加登录需要的两个cookie
12 c = requests.cookies.RequestsCookieJar()
13 c.set(’.CNBlogsCookie’, ‘xxx’) # 填上面抓包内容
14 c.set(’.Cnblogs.AspNetCore.Cookies’,‘xxx’) # 填上面抓包内容
15 s.cookies.update©
16 print s.cookies
17 # 登录成功后保存编辑内容
18 url2= “https://i.cnblogs.com/EditPosts.aspx?opt=1”
19 body = {"__VIEWSTATE": “”,
20 “__VIEWSTATEGENERATOR”:“FE27D343”,
21 “EditorEditEditEdittxbTitle”:“这是绕过登录的标题:北京-宏哥”,
22 “EditorEditEditEditEditorBody”:“

这里是中文内容:http://www.cnblogs.com/duhong/

”,
23 “Editor EditEditEditAdvanced ckbPublished":"on",24"EditorckbPublished":"on", 24 "EditorckbPublished":"on",24"EditorEdit AdvancedAdvancedAdvancedchkDisplayHomePage”:“on”,
25 “Editor EditEditEditAdvanced chkComments":"on",26"EditorchkComments":"on", 26 "EditorchkComments":"on",26"EditorEdit AdvancedAdvancedAdvancedchkMainSyndication”:“on”,
27 “Editor EditEditEditlkbDraft”:“存为草稿”,
28 }
29 r2 = s.post(url2, data=body, verify=False)
30 print r.content

python接口自动化(十三)--cookie绕过验证码登录(详解)相关推荐

  1. python接口自动化(七)--状态码详解对照表(详解)

    简介 我们为啥要了解状态码,从它的作用,就不言而喻了.如果不了解,我们就会像个无头苍蝇,横冲直撞.遇到问题也不知道从何处入手,就是想找别人帮忙,也不知道是找前端还是后端的工程师. 状态码的作用是:we ...

  2. python绕过验证码登录_python接口自动化(十三)--cookie绕过验证码登录(详解)...

    简介 有些登录的接口会有验证码:短信验证码,图形验证码等,这种登录的话验证码参数可以从后台获取的(或者查数据库最直接).获取不到也没关系,可以通过添加cookie的方式绕过验证码.(注意:并不是所有的 ...

  3. 通过cookie绕过验证码登录(绕过验证码)

    通过cookie绕过验证码登录(绕过验证码) #!/user/bin/env python3 # -*- coding: utf-8 -*- from selenium import webdrive ...

  4. Python接口自动化之cookie、session应用

    ------·今天距2021年260天·------ 这是ITester软件测试小栈第112次推文 在上一篇Python接口自动化测试系列文章:Python接口自动化-requests模块之post请 ...

  5. python接口自动化之cookie,session,token鉴权解决方案

    http协议:简单.快捷.无连接.无状态.多次请求之间是没有关联的,独立的. 一.cookie鉴权 1.什么是cookie? cookie是在服务器产生的存储在客户端的一小段文本信息,格式是字典,键值 ...

  6. python 接口测试 如何写配置文件_python接口自动化之ConfigParser配置文件的使用详解...

    前言:目前我们使用的绝大多数计算机程序,无论是办公软件,浏览器,甚至游戏.视频都是通过菜单界面系统配置的,它几乎成了我们使用机器的默认方式.而在python中,也有这样的一个配置模块可以把代码可配置化 ...

  7. python接口脚本实例_python图形用户接口实例详解

    本文实例为大家分享了python图形用户接口实例的具体代码,供大家参考,具体内容如下 运用tkinter图形库,模拟聊天应用界面,实现信息发送. from tkinter import * impor ...

  8. python通过cookie绕过验证码_Python Selenium Cookie 绕过验证码实现登录示例代码

    之前介绍过通过cookie 绕过验证码实现登录的方法.这里并不多余,会增加分析和另外一种方法实现登录. 1.思路介绍 1.1.直接看代码,内有详细注释说明 # FileName : Wm_Cookie ...

  9. Python接口自动化之登录接口测试

    VOL 117 29 2020-04 今天距2020年246天 这是ITester软件测试小栈第117次推文 点击上方蓝字"ITester软件测试小栈"关注我,每周一.三.五早上  ...

最新文章

  1. Visual Studio插件
  2. C# 结构体 简明介绍
  3. 时间串变成Date类型的数据
  4. elk+redis分布式分析nginx日志
  5. 双纵坐标的绘图命令_工程师绘图必备软件——OriginLab 2019b
  6. DDOS的攻击原理和防护指南
  7. c++注释快捷键_JAVA编程中你一定要掌握的“快捷键”
  8. linux系统磁盘的分配空间不足,Linux系统磁盘空间不足解决办法
  9. 凸优化第六章逼近与拟合 6.1 范数逼近
  10. MyBatis学习(二)使用注解开发、Mybatis 执行流程、一对多多对一的结果集映射
  11. 计算机二级公共基础知识资料(考点集合)
  12. 关于穿透冰点还原等还原软件的方法
  13. Dubbo-接口数据序列化Serialization
  14. 程序员幽默:39个奇葩代码注释,每一个都能笑抽
  15. 用python画一个机器猫歌词_用Python语言模型和LSTM做一个Drake饶舌歌词生成器!自己蒙了!...
  16. openwrt校园网自动登录且断网重连
  17. oracle px execute reply,(转)PX Deq: Execute Reply 案例说明
  18. 【C++】初窥门径---入门篇
  19. JAVA多线程解决哲学家问题(GUI演示)
  20. linux下编译C++项目

热门文章

  1. 精悍的Python代码段-转
  2. javaScript 中 call 函数的用法说明
  3. PowerDesigner12.5 破解,汉化下载(转载)
  4. 用 Python 分析上网记录,发现了很多不可思议的事
  5. 电子书下载:Construct Game Development Beginner's Guide
  6. 我心中的核心组件(可插拔的AOP)~大话开篇及目录
  7. Leetcode - 广度优先遍历专题
  8. [转]Vmware ESX 4上虚拟机 Redhat 5.2(CentOS 5.2)启动在Starting udev 停几个小时
  9. Qt5 提示:无法启动此程序,计算机丢失Qt5Widgetsd.dll的解决方法
  10. LOL(英雄联盟)提示不支持虚拟机登录,解决方法