首页
学习
活动
专区
圈层
工具
发布
42 篇文章
1
python接口自动化(一)--什么是接口、接口优势、类型(详解)
2
python接口自动化(二)--什么是接口测试、为什么要做接口测试(详解)
3
python接口自动化(三)--如何设计接口测试用例(详解)
4
python接口自动化(四)--接口测试工具介绍(详解)
5
python接口自动化(五)--接口测试用例和接口测试报告模板(详解)
6
python接口自动化(六)--发送get请求接口(详解)
7
python接口自动化(七)--状态码详解对照表(详解)
8
python接口自动化(八)--发送post请求的接口(详解)
9
python接口自动化(九)--python中字典和json的区别(详解)
10
python接口自动化(十)--post请求四种传送正文方式(详解)
11
python接口自动化(十一)--发送post【data】(详解)
12
python接口自动化(十二)--https请求(SSL)(详解)
13
python接口自动化(十三)--cookie绕过验证码登录(详解)
14
python接口自动化(十四)--session关联接口(详解)
15
python接口自动化(十五)--参数关联接口(详解)
16
python接口自动化(十六)--参数关联接口后传(详解)
17
python接口自动化(十七)--Json 数据处理---一次爬坑记(详解)
18
python接口自动化(十八)--重定向(Location)(详解)
19
python接口自动化(十九)--Json 数据处理---实战(详解)
20
python接口自动化(二十)--token登录(详解)
21
python接口自动化(二十一)--unittest简介(详解)
22
python接口自动化(二十二)--unittest执行顺序隐藏的坑(详解)
23
python接口自动化(二十三)--unittest断言——上(详解)
24
python接口自动化(二十四)--unittest断言——中(详解)
25
python接口自动化(二十五)--unittest断言——下(详解)
26
python接口自动化(二十六)--批量执行用例 discover(详解)
27
python接口自动化(二十七)--html 测试报告——上(详解)
28
python接口自动化(二十八)--html测试 报告——下(详解)
29
python接口自动化(二十九)--html测试报告通过邮件发出去——上(详解)
30
python接口自动化(三十)--html测试报告通过邮件发出去——中(详解)
31
python接口自动化(三十一)--html测试报告通过邮件发出去——下(详解)
32
python接口自动化(三十二)--Python发送邮件(常见四种邮件内容)番外篇——上(详解)
33
python接口自动化(三十三)-python自动发邮件总结及实例说明番外篇——下(详解)
34
python接口自动化(三十四)-封装与调用--函数和参数化(详解)
35
python接口自动化(三十五)-封装与调用--流程类接口关联(详解)
36
python接口自动化(三十六)-封装与调用--流程类接口关联续集(详解)
37
python接口自动化(三十七)-封装与调用--读取excel 数据(详解)
38
python接口自动化(三十八)-python操作mysql数据库(详解)
39
python接口自动化(三十九)- logger 日志 - 上(超详解)
40
python接口自动化(四十)- logger 日志 - 下(超详解)
41
python接口自动化(四十一)- 发xml格式参数的post请求(超详解)
42
python接口自动化(四十二)- 项目结构设计之大结局(超详解)

python接口自动化(十一)--发送post【data】(详解)

简介 

  前面登录博客园的是传 json 参数,由于其登录机制的改变没办法演示,然而在工作中有些登录不是传 json 的,如 jenkins 的登录,这里小编就以jenkins 登录为案例,传 data 参数,给各位童鞋详细演练一下。

一、登录jenkins抓包

1、浏览器上登录jenkins,输入账号和密码,点击登录

2、fiddler抓包工具抓取jenkins登录的过程

3、可以清楚地看到这个body参数并不是json格式,是key=value格式,也就是前面介绍post请求四种数据类型里面的第一种

二、请求头部

1.上面抓包已经知道body的数据类型了,那么头部里面Content-Type类型也需要填写对应的参数类型

三、实现登录

1、登录实例代码如下:

注意:此处的登录URL是fiddler抓包抓到的,而并非是浏览器的URL地址,如果你复制的是浏览器的地址,就会报错了

代码语言:javascript
复制
 1 # coding:utf-8
 2 import requests
 3 # 先打开登录首页,获取部分session
 4 url = "http://localhost:8080/jenkins/j_acegi_security_check"
 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 d = {"j_username": "admin",
 9      "j_password": "111111",
10      "from": "",
11      "Submit": u"登录",
12      "remember_me": "on"
13      }
14 s = requests.session()
15 r = s.post(url, headers=headers, data=d)
16 print (r.content.decode('utf-8')

2、运行后的结果如下:

3、为了更好地查看你可以将其拷贝到记事本,保存,然后将文件后缀名修改成.html或者.htm,用浏览器打开查看

四、判断登录是否成功

1.首先这个登录接口有重定向,看左边会话框302,那登录成功的结果看最后一个200就行

2.返回的结果并不是跟博客园一样的json格式,返回的是一个html页面

五、判断登录成功

1.判断登录成功,可以抓取页面上的关键元素,比如:账号名称admin,注销按钮

2.通过正则表达式提出这2个关键字

六、参考代码

代码语言:javascript
复制
 1 # coding:utf-8
 2 import requests
 3 # 先打开登录首页,获取部分session
 4 url = "http://localhost:8080/jenkins/j_acegi_security_check"
 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 d = {"j_username": "admin",
 9      "j_password": "111111",
10      "from": "",
11      "Submit": u"登录",
12      "remember_me": "on"
13      }
14 s = requests.session()
15 r = s.post(url, headers=headers, data=d)
16 #print (r.content.decode('utf-8'))
17 # 正则表达式提取账号和登录按钮
18 import re
19 t = re.findall(r'<b>(.+?)</b>', r.content.decode('utf-8'))   # 用python3的这里r.content需要解码
20 print (t[0])
21 print (t[1])

七、遇到问题可解决方法

注意这里边遇到的问题python3遇到的问题,或许python2没有这些问题,笔者没有实践,有兴趣的自己可以试一下

1、如果打印content,没有加后边的.decode('utf-8'),会出现乱码,解决方法加上即可。

2、如果正则提取没有加.decode('utf-8'),会报如下错误,解决方案也是加上即可

八、小结

  jenkins 代码模拟登陆到这里就结束,实际工作中的登录接口也就是这些,记住万变不离其宗,举一反三。

下一篇
举报
领券