python接口自动化8-参数化【转载】
本篇转自博客:上海-悠悠
原文地址:http://www.cnblogs.com/yoyoketang/tag/python%E6%8E%A5%E5%8F%A3%E8%87%AA%E5%8A%A8%E5%8C%96/
前言
前面一篇实现了参数的关联,那种只是记流水账的完成功能,不便于维护,也没什么可读性,接下来这篇可以把每一个动作写成一个函数,这样更方便了。
参数化的思维只需记住一点:不要写死
(由于博客园登录机制变了,登录全部用cookie,不用账号和密码登录了)
一、登录函数
1.s参数是session的一个实例类,先放这里,方便写后面代码
2.登录函数传三个参数,s是需要调用前面的session类,所以必传,可以传个登录的url,然后payload是账号和密码
二、保存草稿
1.编辑内容的标题title和正文body_data参数化了,这样后面可以方便传不同值
2.这里返回了获取到新的url地址,因为后面的postid参数需要在这里提取
三、提取postid
1.这里用正则表达式提取url里面的postid
四、删除草稿
1.传个url和postid就可以了
五、参考代码:
# coding:utf-8
import requests
def login(s, url, payload):
'''登录'''
# 先打开登录首页,获取部分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"
} # get方法其它加个ser-Agent就可以了
s = requests.session()
r = s.get(url, headers=headers,verify=False)
print s.cookies
# 添加登录需要的两个cookie
c = requests.cookies.RequestsCookieJar()
c.set('.CNBlogsCookie', '这里是抓到的') # 填上面抓包内容
c.set('.Cnblogs.AspNetCore.Cookies','这里是抓到的') # 填上面抓包内容
c.set('AlwaysCreateItemsAsActive',"True")
c.set('AdminCookieAlwaysExpandAdvanced',"True")
s.cookies.update(c)
print s.cookies
def save_box(s, url2, title, body_data):
'''# 获取报存之后url地址'''
body = {"__VIEWSTATE": "",
"__VIEWSTATEGENERATOR":"FE27D343",
"Editor$Edit$txbTitle":"这是标题",
"Editor$Edit$EditorBody":"<p>这里正文:http://www.cnblogs.com/yoyoketang/</p>",
"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 r2.url
return r2.url
def get_postid(u):
'''正则提取postid'''
import re
postid = re.findall(r"postid=(.+?)&", u)
print postid # 这里是list
if len(postid) < 1:
return ''
else:
return postid[0]
def delete_box(s,url3, postid):
'''删除草稿箱'''
json3 = {"postId": postid}
r3 = s.post(url3, json=json3, verify=False)
print r3.json()
if __name__ == "__main__":
url = "https://passport.cnblogs.com/user/signin"
payload = {
"input1": "xxx",
"input2": "xxx",
"remember": True
}
s = requests.session()
login(s, url, payload,)
url2 = "https://i.cnblogs.com/EditPosts.aspx?opt=1"
u = save_box(s, url2, "标题", "正文内容")
postid = get_postid(u)
url3 = "https://i.cnblogs.com/post/delete"
delete_box(s, url3, postid)
最新文章
- Apache服务器在80端口配置多域名虚拟主机的方法
- AngularJs Cookies 操作
- Mvc导入导出Excel
- oracle远程连接太慢
- 六间房 去掉水印的方法 绕过游客VIP限制
- 一、java环境搭建
- Scout YYF I(POJ 3744)
- JavaScript闭包基本概念
- Android更新主线程UI的两种方式handler与runOnUiThread()
- C#基础语法
- odoo 基于SQL View视图的model类
- rosetta deep_analysis
- Dynamics CRM Instances
- 二. Redis 安全性
- Cracking The Coding Interview 5.7
- java基础基础总结----- RunTime
- git for windows配置SSH key
- 备忘录:在alpine上安装kvm
- test20181021 快速排序
- 管理Linux服务器的用户和组