通过Apache JMeter连接到自签名SSL网站

时间:2013-03-01 17:07:50

标签: apache ssl jmeter

我尝试在使用自签名SSL证书的网站上进行性能测试。

我的JMeter测试计划在“通常”SSL站点(具有正确签名的证书)和没有SSL的测试页面上正常工作。一旦我访问测试页面(使用自签名证书),JMeter只会创建错误。我尝试过:

  1. 存储证书(通过浏览器)并将其导入Java(通过控制面板“Java”)

  2. 将证书添加到密钥库并通过以下命令行启动JMeter(我不知道如何以另一种方式“引用JVM中的密钥库”?)

      

    java -jar“ApacheJMeter.jar”-Djavax.net.ssl.keyStore =“C:\ Program Files \ Java \ jre7 \ lib \ security \ cacerts”-Djavax.net.ssl.keyStorePassword = changeit

  3. 感谢您提示如何让JMeter访问测试页面:)

    结果(JMeter输出)目前是:

    javax.net.ssl.SSLHandshakeException: Remote host closed connection during handshake
        at sun.reflect.GeneratedConstructorAccessor28.newInstance(Unknown Source)
        at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
        at java.lang.reflect.Constructor.newInstance(Unknown Source)
        at sun.net.www.protocol.http.HttpURLConnection$6.run(Unknown Source)
        at sun.net.www.protocol.http.HttpURLConnection$6.run(Unknown Source)
        at java.security.AccessController.doPrivileged(Native Method)
        at sun.net.www.protocol.http.HttpURLConnection.getChainedException(Unknown Source)
        at sun.net.www.protocol.http.HttpURLConnection.getInputStream(Unknown Source)
        at java.net.HttpURLConnection.getResponseCode(Unknown Source)
        at sun.net.www.protocol.https.HttpsURLConnectionImpl.getResponseCode(Unknown Source)
        at org.apache.jmeter.protocol.http.sampler.HTTPJavaImpl.readResponse(HTTPJavaImpl.java:264)
        at org.apache.jmeter.protocol.http.sampler.HTTPJavaImpl.sample(HTTPJavaImpl.java:520)
        at org.apache.jmeter.protocol.http.sampler.HTTPSamplerProxy.sample(HTTPSamplerProxy.java:62)
        at org.apache.jmeter.protocol.http.sampler.HTTPSamplerBase.sample(HTTPSamplerBase.java:1088)
        at org.apache.jmeter.protocol.http.sampler.HTTPSamplerBase.sample(HTTPSamplerBase.java:1077)
        at org.apache.jmeter.threads.JMeterThread.process_sampler(JMeterThread.java:428)
        at org.apache.jmeter.threads.JMeterThread.run(JMeterThread.java:256)
        at java.lang.Thread.run(Unknown Source)
    Caused by: javax.net.ssl.SSLHandshakeException: Remote host closed connection during handshake
        at sun.security.ssl.SSLSocketImpl.readRecord(Unknown Source)
        at sun.security.ssl.SSLSocketImpl.performInitialHandshake(Unknown Source)
        at sun.security.ssl.SSLSocketImpl.startHandshake(Unknown Source)
        at sun.security.ssl.SSLSocketImpl.startHandshake(Unknown Source)
        at sun.net.www.protocol.https.HttpsClient.afterConnect(Unknown Source)
        at sun.net.www.http.HttpClient.parseHTTPHeader(Unknown Source)
        at sun.net.www.http.HttpClient.parseHTTP(Unknown Source)
        at sun.net.www.protocol.http.HttpURLConnection.getInputStream(Unknown Source)
        at sun.net.www.protocol.http.HttpURLConnection.getHeaderField(Unknown Source)
        at java.net.URLConnection.getHeaderFieldLong(Unknown Source)
        at java.net.URLConnection.getContentLengthLong(Unknown Source)
        at java.net.URLConnection.getContentLength(Unknown Source)
        at sun.net.www.protocol.https.HttpsURLConnectionImpl.getContentLength(Unknown Source)
        at org.apache.jmeter.protocol.http.sampler.HTTPJavaImpl.readResponse(HTTPJavaImpl.java:230)
        ... 7 more
    Caused by: java.io.EOFException: SSL peer shut down incorrectly
        at sun.security.ssl.InputRecord.read(Unknown Source)
        ... 21 more
    

1 个答案:

答案 0 :(得分:1)

看看这个答案:JMeter and optional SSL client certificate在JMeter HTTP请求中查看您的端口号。 https的Stadard端口是443。