scala - Gatling - 根据请求更改馈线中使用的 SSL 证书?

标签 scala ssl https gatling

是否可以在 Gatling 中为每个请求使用不同证书的馈线?

考虑测试:

  • 对于许多用户,每个用户都有一个用于 HTTPS 连接的个人唯一证书,
  • 为每个用户发送一个请求,使用该用户的证书。

示例实现:

val feeder = Array(
  Map("data" -> data(user1_data),
    "gatling.http.ssl.trustStore.file" -> "/tmp/test-data/rb.jks",
    "gatling.http.ssl.trustStore.password" -> "password",
    "gatling.http.ssl.keyStore.file" -> "/tmp/test-data/user1.jks",
    "gatling.http.ssl.keyStore.password" -> "password"),

  Map("data" -> data(user2_data),
    "gatling.http.ssl.trustStore.file" -> "/tmp/test-data/rb.jks",
    "gatling.http.ssl.trustStore.password" -> "password",
    "gatling.http.ssl.keyStore.file" -> "/tmp/test-data/user2.jks",
    "gatling.http.ssl.keyStore.password" -> "password")
)
...
val scn = scenario.exec(reportableTest(
  repeat(feeder.length) {
    feed(feeder)
    .exec(http("test user personal data")
    .post(user_url)
    .headers(user_headers)
    .body(StringBody("${data}")).asJSON
    .check(
      status.is(201),
      header("Content-type").is("application/json"),
    )
}))

我确实在场景设置中调用了:.disableClientSharing。

奇怪的是,似乎只有第一个

"gatling.http.ssl.keyStore.file" -> "/tmp/test-data/user1.jks",

已处理。下一个不是(即使我创建了另一个 reportableTest)。我只是更改了顺序以查看实际上在两个请求中都使用了第一个“userX.jks”。

这是正常行为吗? 是错误吗?

最佳答案

在 Gatling 的 Google Group 上回答:SSL 配置可以为每个虚拟用户设置,而不是每个请求。

关于scala - Gatling - 根据请求更改馈线中使用的 SSL 证书?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28694659/

相关文章:

Android - 通过 HTTPS 进行渐进式下载

ssl - OpenSSL 和 CAPI - 证书冲突

scala - 在 Windows 10 上安装 Spark 后出现问题

斯卡拉/Play : load template dynamically

scala - scala 的图形库

tomcat - 无法从本地主机建立 SSL 连接

spring-boot - 为什么我收到无效的 csrf token ?

.htaccess - domain.com 神秘重定向到 https ://www. domain.com - 可能是什么原因造成的?

security - SSL 证书 (CA) 如何准确验证?

java - 类型不匹配错误(Scala)