python接口自动化登录_python接口自动化三(登录绕开验证码及发帖)

本文介绍如何利用抓包工具获取登录cnblogs的cookie,绕过验证码,轻松实现自动化登录。主要内容包括使用Fiddler抓取cookie,理解cookie结构,添加cookie到session并实际操作示例。
摘要由CSDN通过智能技术生成

前言

有些登录的接口会有验证码:短信验证码,图形验证码等,这种登录的话验证码参数可以从后台获取的(或者查数据库最直接)。

获取不到也没关系,可以通过添加cookie的方式绕过验证码。

但是这里需要明确一点,验证码本就是为了防止用户自动化的,如果可以的话可以直接让开发给个万能验证码,没必要在验证码这里浪费时间。

一、抓登录cookie

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

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

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

1613467-20190520112010057-1609168881.png

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

1613467-20190520112037370-1896511836.png

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

1613467-20190520112101598-1563069563.png

二、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(coo)

3.于是添加登录的cookie,把第一步fiddler抓到的内容填进去就可以了

c =requests.cookies.RequestsCookieJar()

c.set('.CNBlogsCookie', '抓取的cookie')

c.set('.Cnblogs.AspNetCore.Cookies','抓取的cookie')

s.cookies.update(c)print(s.cookies)

1613467-20190520112505952-2042765469.png

四、添加新随笔

抓取发帖的cookie

1613467-20190520112902513-756949905.png

编辑自己想要输入的内容

1613467-20190520112745182-995079999.png

五、参考代码

#coding:utf-8

importrequestsimporturllib3

urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)#这行是预防报错写的#先打开登录首页,获取部分cookie

url = "https://passport.cnblogs.com/user/signin"headers={"User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:44.0) Gecko/20100101 Firefox/44.0"}

s=requests.session()

r= s.get(url, headers=headers, verify=False)print(s.cookies)#添加登录需要的两个cookie

c =requests.cookies.RequestsCookieJar()

c.set('.CNBlogsCookie', '填上面抓到的cookie') #填上面抓包内容

c.set('.Cnblogs.AspNetCore.Cookies', '填上面抓到的cookie') #填上面抓包内容

s.cookies.update(c)print(s.cookies)print(r.text)#登录成功后保存编辑内容

r1 = s.get("https://i.cnblogs.com/EditPosts.aspx?opt=1", headers=headers, verify=False)#保存草稿箱

url2 = "https://i.cnblogs.com/EditPosts.aspx?opt=1"body= {"__VIEWSTATE": "","__VIEWSTATEGENERATOR": "FE27D343","Editor$Edit$txbTitle": "这是测试标题","Editor$Edit$EditorBody": "

这里是测试正文","Editor$Edit$Advanced$ckbPublished": "on","Editor$Edit$Advanced$chkDisplayHomePage": "on","Editor$Edit$Advanced$chkComments": "on","Editor$Edit$Advanced$chkMainSyndication": "on","Editor$Edit$Advanced$txbEntryName": "","Editor$Edit$Advanced$txbExcerpt": "","Editor$Edit$Advanced$tbEnryPassword": "","Editor$Edit$lkbDraft": "存为草稿",

}

r2= s.post(url2, data=body, verify=False)print(r.content.decode())

执行之后就会保存新的随笔草稿

1613467-20190520114117416-809197805.png

参考链接:https://www.cnblogs.com/yoyoketang/p/6833355.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值