zoukankan      html  css  js  c++  java
  • ngrinder脚本请求头中添加cookie后仍报未登录或者401错误问题解决

     

    使用ngrinder做接口的压力测试时,有时需要先进行登录,登录后产生cookie,登录后操作需要带上这个cookie才可以请求成功,这里介绍下ngrinder脚本中添加请求头的方法,如下
    // 添加请求头

    List<NVPair> headerList = new ArrayList<NVPair>()
    headerList.add(new NVPair("Cookie", "intranet-pre-sessionid=2894FDD3CA636343B9E6C24A1549E013; Path=/; Domain=.xxxx.com; HttpOnly;"))
    headers = headerList.toArray()

    // 将请i去头添加到请求中
    request.setHeaders(headers)
     
    以为做完以上这些就可以了,但实际操作发现登录成功后,将生成的cookie放到其它请求的请求头中执行测试仍然报“未登录”或者401错误码,查阅资料发现原因是由于ngrinder默认会在setheader的时候把传进来的cookie和header去掉,因此,需要先进行下面的设置,然后再设置请求头
    HTTPPluginControl.getConnectionDefaults().setUseCookies(false)
     
    下面是我的脚本实例(部分代码)
     
    Ngrinder的cookie处理

    1) 登录产生cookie
    @BeforeThread
    login_get_cookie(); // 调用登录方法
    cookies = CookieModule.listAllCookies(HTTPPluginControl.getThreadHTTPClientContext()); // 配置cookie管理器
    2) 读取控制器中cookie
    @Before
    cookies.each { CookieModule.addCookie(it, HTTPPluginControl.getThreadHTTPClientContext()) }

     
  • 相关阅读:
    读《SQL优化核心思想》:你不知道的优化技巧
    MySQL 索引建立原则及注意事项
    MySQL 捕获有问题的SQL-慢查日志 实例
    MySQL 分区间进行数据展示 实例
    MySQL 删除重复数据实例
    MySql 索引优化实例
    JDK1.6 Java.lang.Null.Pointer.Exception
    关于 MySQL LEFT JOIN 不可不知的事
    搞定queryString
    数据库不得不说的陷阱
  • 原文地址:https://www.cnblogs.com/shengs/p/15426900.html
Copyright © 2011-2022 走看看