首页
学习
活动
专区
圈层
工具
发布
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接口自动化(二十)--token登录(详解)

简介

  为了验证用户登录情况以及减轻服务器的压力,减少频繁的查询数据库,使服务器更加健壮。有些登录不是用 cookie 来验证的,是用 token 参数来判断是否登录。token 传参有两种一种是放在请求头里,本质上是跟 cookie 是一样的,只

是换个单词而已;另外一种是在 url 请求参数里,这种更直观。

登录返回token

1、如下图的这个登录接口,就是没有 cookies的登录接口。

2、但是这个登录接口,登录成功后有返回token,如下图

请求头带token

1、登录成功后继续操作其它页面,发现post请求的请求头,都会带有token参数

2、这种请求其实比cookie更简单,直接把登录后的token放到头部即可

token关联

1、用脚本实现登录,获取token参数,获取后传参到请求头就可以了

2、如果登录有验证码,前面的脚本登录步骤就省略了,自己手动登录后获取token

参考代码

代码语言:javascript
复制
 1 # coding:utf-8
 2 import requests
 3 header = {   # 登录抓包获取的头部
 4         "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:44.0) Gecko/20100101 Firefox/44.0",
 5         "Accept": "*/*",
 6         "Accept-Language": "zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3",
 7         "Accept-Encoding": "gzip, deflate",
 8         "Content-Type": "application/x-www-form-urlencoded; charset=UTF-8",
 9         "X-Requested-With": "XMLHttpRequest",
10         "Content-Length": "423",
11         "Connection": "keep-alive"
12         }
13 body = {"key1": "value1",
14         "key2": "value2"}  # 这里账号密码就是抓包的数据
15 s = requests.session()
16 login_url = "http://xxx.login"   # 自己找带token网址
17 login_ret = s.post(login_url, headers=header, data=body)
18 # 这里token在返回的json里,可以直接提取
19 token = login_ret.json()["token"]
20 # 这是登录后发的一个post请求
21 post_url = "http://xxx"
22 # 添加token到请求头
23 header["token"] = token
24 # 如果这个post请求的头部其它参数变了,也可以直接更新
25 header["Content-Length"]="9"
26 body1 = {
27          "key": "value"
28          }
29 post_ret = s.post(post_url, headers=header, data=body1)
30 print post_ret.content

小结

Token的意义及用法

一.Token的来源:

当客户端多次向服务端请求数据时,服务端就需要多次从数据库中查询用户名和密码并进行对比,判断用户名和密码是否正确,并作出相应提示。但这样无疑会增加服务器端的运行压力,是否可以有一种方式只需要验证用户就是之前的用

户而不需要每次在客户端请求数据时都需要查询数据库判断用户名和密码是否正确。在这种请求下,引入了token来解决服务器端多次访问数据库问题。

1、什么是Token:

Token是服务端端生成的一串字符串,作为客户端进行请求时辨别客户身份的的一个令牌。当用户第一次登录后,服务器生成一个Token便将此Token返回给客户端,以后客户端只需带上这个Token前来请求数据即可,无需再次带上用户名和密码。

2、使用Token的目的:

Token的目的是为了验证用户登录情况以及减轻服务器的压力,减少频繁的查询数据库,使服务器更加健壮。

二. Token的运用流程:

1、当用户首次登录成功之后, 服务器端就会生成一个 token 值,这个值,会在服务器保存token值(保存在数据库中),再将这个token值返回给客户端;

2、客户端拿到 token 值之后,进行保存 (保存位置由服务器端设置);

3、以后客户端再次发送网络请求(一般不是登录请求)的时候,就会将这个 token 值附带到参数中发送给服务器.;

4、服务器接收到客户端的请求之后,会取出token值与保存在本地(数据库)中的token值进行比较;

5、如果两个 token 值相同, 说明用户登录成功过!当前用户处于登录状态;

6、如果没有这个 token 值, 没有登录成功;

7、如果 token 值不同: 说明原来的登录信息已经失效,让用户重新登录;

8、Django Rest framework中JWT的使用稍有差异,这里不做详细说明。

下一篇
举报
领券