zoukankan      html  css  js  c++  java
  • Java自动化 接口测试Cookie与token

    一、Cookie与token机制测试

     
    Cookie与Session

    token机制

    cookie/session机制需要在服务端保存大量的session信息,造成严重负担,而token机制则避免记录大量信息,采用服务器签发的token完成验证。
    1、客户端使用用户名跟密码请求登录
    2、服务端收到请求,去验证用户名与密码
    3、验证成功后,服务端会签发一个 Token,再把这个 Token 发送给客户端
    4、客户端收到 Token 以后可以把它存储起来,比如放在 Cookie 里或者 Local Storage 里
    5、客户端每次向服务端请求资源的时候需要带着服务端签发的 Token
    6、服务端收到请求,然后去验证客户端请求里面带着的 Token,如果验证成功,就向客户端返回请求的数据
    相当于酒店在你入住之后,给你一段暗号,之后再来酒店,报暗号就可以入住了。

    Cookie与token测试

    加载与清空cookieStore
    Httpclient提供了cookieStore类用于加载和读取cookies。
    通过private CookieStore cookies = new BasicCookieStore();创建cookieStore
    在构建httpclient时通过.setDefaultCookieStore(cookies)方法加载。
    也可以通过添加头域Cookie的方式来添加Cookie。
    通过一个布尔类型的标识参数来决定是否需要加载cookies。

    添加token到请求头域
    token通常在头域中被添加,当需要添加头域参数时,通过布尔类型的标识参数来决定是否设置新的头域。
    通过setHeader方法完成头域的添加。

    二、头域添加与参数传递

    头域操作
    为了方便头域信息键值对的传递和反复使用,并且方便方法封装时调用。使用map来保存头域信息的键值对,并通过循环遍历将头域headermap中的内容添加到http请求中使用。

     
    参数传递

    Httpclient方法封装
    为了便于头域的管理和方法反复调用,将存储头域的map作为关键字类的成员变量,通过布尔变量来控制方法是否需要添加头域。
    并设计方法实现该成员变量map赋值和清空。
    同理,cookiestore也通过类似机制来管理是否需要使用cookie。

    三、关键字需求封装

    完成httpclientkw类的封装之后,发包流程的操作已经封装完成,基本操作已实现,接下来封装测试过程中的需求,以完成测试操作。

     
    关键字需求封装

    断言实现
    将每次发包方法调用返回结果赋值给成员变量response,针对response进行断言操作。

    头域参数json格式转换
    为便于头域参数的管理,将头域参数写为json格式,通过json转换为map,再传递给HttpclientKw的addheader方法操作。

    彻底理解cookie,session,token



    作者:Lyle莱尔
    链接:https://www.jianshu.com/p/6a79ec04a9f3

  • 相关阅读:
    C#执行异步操作的几种方式
    spring boot swagger ui使用 nginx 部署后无法使用问题
    PHP支付宝接口RSA验证
    认证加密算法php hash_hmac和java hmacSha1的问题
    如何实现从 Redis 中订阅消息转发到 WebSocket 客户端
    ffmpeg安装
    nginx静态资源反向代理
    Redis基础知识 之——发布/订阅
    linux下安装git
    php实现无限级分类查询(递归、非递归)
  • 原文地址:https://www.cnblogs.com/zgq123456/p/12614441.html
Copyright © 2011-2022 走看看