有些登陆的接口会有验证码:短信验证码,图形验证码等,这种登陆的话验证码参数能够从后台获取的(或者查数据库最直接)。获取不到也不要紧,能够经过添加cookie的方式绕过验证码。(注意:并非全部的登陆都是用cookie来保数据库
持登陆的,有些是用token登陆)浏览器
一、如博客园登陆后会生成一个已登陆状态的cookie,那么只须要直接把这个值添加到cookies里面就能够了。bash
二、能够先手动登陆一次,而后抓取这个cookie,这里就须要用抓包工具fiddler了服务器
三、先打开博客园登陆界面,手动输入帐号和密码(勾选下次自动登陆)微信
四、打开fiddler抓包工具,刷新下登陆首页,就是登陆前的cookie了cookie
五、登陆成功后,再查看cookie变化,发现多了两组参数,多的这两组参数就是咱们想要的,copy出来,一会有用session
一、用抓包工具fidller只能看到cookie的name和value两个参数,实际上cookie还有其它参数dom
二、如下是一个完整的cookie组成结构工具
1
2
3
4
5
6
7
|
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的名称post
value:cookie对应的值,动态生成的
domain:服务器域名
expiry:Cookie有效终止日期
path:Path属性定义了Web服务器上哪些路径下的页面可获取服务器设置的Cookie
httpOnly:防脚本攻击
secure:在Cookie中标记该变量,代表只有当浏览器和Web Server之间的通讯协议为加密认证协议时,
浏览器才向服务器提交相应的Cookie。当前这种协议只有一种,即为HTTPS。
一、往session里面添加cookie能够用如下方式
二、set里面参数按括号里面的参数格式
1
2
3
|
coo = requests.cookies.RequestsCookieJar()
coo.
set
(
'cookie-name'
,
'cookie-value'
, path=
'/'
, domain=
'.xxx.com'
)
s.cookies.update(c)
|
三、因而添加登陆的cookie,把第一步fiddler抓到的内容填进去就能够了
1
2
3
4
5
|
c = requests.cookies.RequestsCookieJar()
c.
set
(
'.CNBlogsCookie'
,
'xxx'
)
c.
set
(
'.Cnblogs.AspNetCore.Cookies'
,
'xxx'
)
s.cookies.update(c)
print(s.cookies)
|
一、看到刚刚添加的随笔
一、因为登陆时候是多加2个cookie,咱们能够先用get方法打开登陆首页,获取部分cookie
二、再把登陆须要的cookie添加到session里
三、添加成功后,随便编辑正文和标题保存到草稿箱
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(c)
16 print s.cookies
17 # 登陆成功后保存编辑内容
18 url2= "https://i.cnblogs.com/EditPosts.aspx?opt=1"
19 body = {"__VIEWSTATE": "",
20 "__VIEWSTATEGENERATOR":"FE27D343",
21 "Editor$Edit$txbTitle":"这是绕过登陆的标题:北京-宏哥",
22 "Editor$Edit$EditorBody":"<p>这里是中文内容:http://www.cnblogs.com/duhong/</p>",
23 "Editor$Edit$Advanced$ckbPublished":"on",
24 "Editor$Edit$Advanced$chkDisplayHomePage":"on",
25 "Editor$Edit$Advanced$chkComments":"on",
26 "Editor$Edit$Advanced$chkMainSyndication":"on",
27 "Editor$Edit$lkbDraft":"存为草稿",
28 }
29 r2 = s.post(url2, data=body, verify=False)
30 print r.content复制代码