- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章浅析Jmeter多用户token使用问题由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
。
在测试的时候,经常会有模拟用户登录,拿到用户 token 后再去请求接口的场景.
这个模拟用户登录就会分为两种,一种是单用户,另一种是多用户.
日常自动化测试的时候可能一个用户对应 n 个用例就可以满足大多数场景; 。
如果是在压力测试的场景下面,可能就会略显单调,也无法满足一些真实业务场景.
对于单用户的情况下,和我们常规的多接口有依赖的测试其实没什么太大的差别.
所以这里主要讲的是多用户产生多个 token 的情况.
下面来看一个具体的例子来了解一下.
。
在这里的话,只有两个接口,一个是登录拿 token,一个是有 token 才能请求的.
下面是各接口定义 。
。
请求:
POST http://localhost:8532/MultiToken/LoginContent-Type: application/json{ "UserName":"catcherwong-1", "Password":"123"}
响应:
{"code":0,"msg":"ok","data":"catcherwong-1-token"}
。
请求:
GET http://localhost:8532//MultiToken/do?account=xxxContent-Type: application/jsontoken: catcherwong-1-token
响应:
{"code":0,"msg":"ok","data":"catcherwong-1-token"}
。
登录接口属于预请求,所以我们一般会选择把它放在 setUp 线程组里面.
我们需要准备一个 csv 文件,里面用来存放需要登录的用户名和密码.
接下来就是把这个 csv 配置好,定义了两个变量 account 和 pwd 。
然后是把登录的 HTTP 请求配置好:
由于后面要用到 token,所以要先把 token 提取出来,这里用的是 JSON Extractor.
到这里就要开始注意了!!!! 。
由于我们会有多个用户进行登录,但是这一个提取操作每次都会把 token 赋值到 access_token 这个变量上面,是覆盖的操作.
换句话就是说,每登录一个用户,这个 access_token 的值就会是最后一个登录的用户的 token,.
换个思路,每次它会覆盖,那么把这些 token 存到一个地方,然后业务接口去这个地方取就可以了.
如果没有用户登录这一步,给的直接是 token,那么我们也是直接把这个 token 放到 csv 文件里面,然后让 jmeter 去循环使用里面的 token.
那么要做的东西其实就很确定了,就是在提取到 token 后,把这个 token 写到一个 csv 文件里面.
要想做到这一步,需要在登录接口后面加一个后置的处理.
String p1 = System.getProperty("user.dir");String p2 = System.getProperty("file.separator");String p3 = "user_token.csv";String path = p1 + p2 + p3;FileWriter fileWriter = new FileWriter(new File(path), true);BufferedWriter writer = new BufferedWriter(fileWriter);writer.append(vars.get("accout")+","+vars.get("access_token")+"");writer.close();fileWriter.close();
这段代码的意思是,把用户名和提取到的 access_token 写进到 csv 文件里面,这个文件在的位置是 jmeter 的目录.
这里是对文件路径做了处理,可以适配所有操作系统的。不会出现说指定了一个 windows 系统的路径,然后放到 linux 系统下面就跑不了了.
还有最重要的一个是,要修改 setUp 线程组的属性,把循环次数改成 3 。因为前面的 csv 文件里面有 3 个用户,这样它才会触发三次登录.
。
业务接口要放到正常的线程组里面,独立于 setUp 线程组.
前面提到,登录后会有一个 csv 文件,所以这里第一个要做的是把 csv 配置好.
上面的截图用的是 ${__P(user.dir,)}${__P(file.separator,)}user_token.csv 这个文件路径,这个在本地环境的 Jmeter 是可以通过的,不过在一些云服务上面是不行的,如阿里云 PTS .
这里可以忽略前面的路径,直接填写 user_token.csv 即可,填这两个,得到的文件路径是一样的,一个是绝对路径一个是相对路径.
然后就是配置 HTTP 请求了 。
PS:不要忘记把请求头也配置了,这里就不截图了.
这里试跑两次,可以发现业务请求的接口,它的 token 请求头每次都是不一样的,在交替变化,这个是符合预期的.
但是会发现生成 csv 文件里面的数据会重复,没有自动清理掉上一次产生的数据。如果上一次产生的 token 过期了,那么用了这些过期的 token === 凉凉.
所以这里还有必要加一步 tearDown 线程组,每次跑完脚本把这个文件删除掉.
String p1 = System.getProperty("user.dir");String p2 = System.getProperty("file.separator");String p3 = "user_token.csv";String path = p1 + p2 + p3;log.info("准备删除文件:" + path);File file = new File(path);if (!file.exists()) { log.info("删除文件失败:" + path + "不存在!");} else { file.delete();}
这个时候跑脚本就基本没什么问题了.
。
多用户获取多 token 再使用的场景其实挺多的,这篇内容简单讲解了老黄正在用的一个方案,如果您有更好的建议,也欢迎一起沟通交流.
老黄把 JMeter 系列的内容都放在 github 了,方便大家查阅和测试.
https://github.com/catcherwong/JmeterSample 。
到此这篇关于聊一聊Jmeter多用户token使用问题的文章就介绍到这了,更多相关Jmeter多用户token使用内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://www.cnblogs.com/catcher1994/p/15419072.html 。
最后此篇关于浅析Jmeter多用户token使用问题的文章就讲到这里了,如果你想了解更多关于浅析Jmeter多用户token使用问题的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
在为 Web 应用程序用例图建模时,为用户可以拥有的每个角色创建一个角色是否更好?或拥有一个角色、用户和一个具有特权的矩阵? guest < 用户 < 版主 < 管理员 1: guest 、用户、版主
我无法使用 Elixir 连接到 Postgres: ** (Mix) The database for PhoenixChat.Repo couldn't be created: FATAL 28P
这个问题已经有答案了: Group by field name in Java (7 个回答) 已关闭 7 年前。 我必须编写一个需要 List 的方法并返回 Map> . User包含 Person
感谢您的帮助,首先我将显示代码: $dotaz = "Select * from customers JOIN contracts where customers.user_id ='".$_SESS
我只想向所有用户中的一个用户显示一个按钮。我尝试了 orderByKey() 但没有成功! 用户模型有 id 成员,我尝试使用 orderByChild("id") 但结果相同! 我什至尝试了以下技巧
我们在工作中从 MongoDB 切换到 Postgres,我正在建立一个 BDR 组。 在这一步,我正在考虑安全性并尽可能锁定。因此,我希望设置一个 replication 用户(角色)并让 BDR
export class UserListComponent implements OnInit{ users; constructor(private userService: UserS
我可以使用 Sonata User Bundle 将 FOS 包集成到 sonata Admin 包中。我的登录功能正常。现在我想添加 FOSUserBundle 中的更改密码等功能到 sonata
在 LinkedIn 中创建新应用程序时,我得到 4 个单独的代码: API key 秘钥 OAuth 用户 token OAuth 用户密码 我在 OAuth 流程中使用前两个。 的目的是什么?最后
所以..我几乎解决了所有问题。但现在我要处理另一个问题。我使用了这个连接字符串: SqlConnection con = new SqlConnection(@"Data Source=.\SQLEX
我有一组“用户”和一组“订单”。我想列出每个 user_id 的所有 order_id。 var users = { 0: { user_id: 111, us
我已经为我的Django应用创建了一个用户模型 class User(Model): """ The Authentication model. This contains the u
我被这个问题困住了,找不到解决方案。寻找一些方向。我正在用 laravel 开发一个新的项目,目前正致力于用户认证。我正在使用 Laravels 5.8 身份验证模块。 对密码恢复 View 做了一些
安装后我正在使用ansible配置几台计算机。 为此,我在机器上本地运行 ansible。安装中的“主要”用户通常具有不同的名称。我想将该用户用于诸如 become_user 之类的变量. “主要”用
我正在尝试制作一个运行 syncdb 的批处理文件来创建一个数据库文件,然后使用用户名“admin”和密码“admin”创建一个 super 用户。 到目前为止我的代码: python manage.
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 6 年前。 Improv
我已在 Azure 数据库服务器上设置异地复制。 服务器上运行的数据库之一具有我通过 SSMS 创建的登录名和用户: https://learn.microsoft.com/en-us/azure/s
我有一个 ionic 2 应用程序,正在使用 native FB Login 来检索名称/图片并将其保存到 NativeStorage。流程是我打开WelcomePage、登录并保存数据。从那里,na
这是我的用户身份验证方法: def user_login(request): if request.method == 'POST': username = request.P
我试图获取来自特定用户的所有推文,但是当我迭代在模板中抛出推文时,我得到“User”对象不可迭代 观看次数 tweets = User.objects.get(username__iexact='us
我是一名优秀的程序员,十分优秀!