python接口自动化(二十)--token登录(详解)

简介: 为了验证用户登录情况以及减轻服务器的压力,减少频繁的查询数据库,使服务器更加健壮。有些登录不是用 cookie 来验证的,是用 token 参数来判断是否登录。token 传参有两种一种是放在请求头里,本质上是跟 cookie 是一样的,只是换个单词而已;另外一种是在 url 请求参数里,这种更直观。

简介


  

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


登录返回token



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

1232840-20190422133002808-130457134.png


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


1232840-20190422133242480-1026765827.png


请求头带token



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


1232840-20190422133616460-702736855.png

 

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


token关联



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

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


参考代码



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

小结



Token的意义及用法


一.Token的来源:

   

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

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


1、什么是Token:

     

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


2、使用Token的目的:

T

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


二. Token的运用流程:


1、当用户首次登录成功之后, 服务器端就会生成一个 token 值,这个值,会在服务器保

存token值(保存在数据库中),再将这个token值返回给客户端;


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


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


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


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


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


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


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

相关文章
|
6月前
|
缓存 自然语言处理 监控
阿里巴巴 item_review 接口深度分析及 Python 实现
阿里巴巴开放平台的 item_review 接口用于获取商品用户评论数据,支持评论内容、评分、买家信息等多维度分析,助力产品优化与市场策略制定。
|
5月前
|
JSON API 数据安全/隐私保护
Python采集淘宝拍立淘按图搜索API接口及JSON数据返回全流程指南
通过以上流程,可实现淘宝拍立淘按图搜索的完整调用链路,并获取结构化的JSON商品数据,支撑电商比价、智能推荐等业务场景。
|
6月前
|
缓存 监控 算法
item_get - Lazada 商品详情详情接口深度分析及 Python 实现
Lazada商品详情接口item_get可获取商品全维度数据,包括价格、库存、SKU、促销及卖家信息,支持东南亚六国站点,适用于竞品监控、定价策略与市场分析,助力跨境卖家精准决策。
|
6月前
|
JSON 监控 数据格式
1688 item_search_app 关键字搜索商品接口深度分析及 Python 实现
1688开放平台item_search_app接口专为移动端优化,支持关键词搜索、多维度筛选与排序,可获取商品详情及供应商信息,适用于货源采集、价格监控与竞品分析,助力采购决策。
|
6月前
|
缓存 供应链 监控
VVIC seller_search 排行榜搜索接口深度分析及 Python 实现
VVIC搜款网seller_search接口提供服装批发市场的商品及商家排行榜数据,涵盖热销榜、销量排名、类目趋势等,支持多维度筛选与数据分析,助力选品决策、竞品分析与市场预测,为服装供应链提供有力数据支撑。
|
6月前
|
缓存 监控 算法
唯品会item_search - 按关键字搜索 VIP 商品接口深度分析及 Python 实现
唯品会item_search接口支持通过关键词、分类、价格等条件检索商品,广泛应用于电商数据分析、竞品监控与市场调研。结合Python可实现搜索、分析、可视化及数据导出,助力精准决策。
|
5月前
|
存储 数据采集 监控
Python定时爬取新闻网站头条:从零到一的自动化实践
在信息爆炸时代,本文教你用Python定时爬取腾讯新闻头条,实现自动化监控。涵盖请求、解析、存储、去重、代理及异常通知,助你构建高效新闻采集系统,适用于金融、电商、媒体等场景。(238字)
789 2
|
6月前
|
缓存 监控 算法
苏宁item_get - 获得商品详情接口深度# 深度分析及 Python 实现
苏宁易购item_get接口可实时获取商品价格、库存、促销等详情,支持电商数据分析与竞品监控。需认证接入,遵守调用限制,适用于价格监控、销售分析等场景,助力精准营销决策。(238字)

推荐镜像

更多