0

Jetty 9.0.4 で SSL を構成しようとしています。私は WebSockets で Jetty を使用し、クライアントには Autobahn Android を使用しています。

これに従って、いくつかの構成を試しました: http://www.eclipse.org/jetty/documentation/current/configuring-ssl.html

そしてこれ: JettyでSSLを構成する

最後に、私は常にこの例外を持っています

2013-07-07 13:36:11.742:WARN:oeji.SelectorManager:qtp1384613607-13-selector-0: 
java.lang.NullPointerException
    at org.eclipse.jetty.server.HttpConnection.<init>(HttpConnection.java:96)
    at org.eclipse.jetty.server.HttpConnectionFactory.newConnection(HttpConnectionFactory.java:61)
    at org.eclipse.jetty.server.SslConnectionFactory.newConnection(SslConnectionFactory.java:86)
    at org.eclipse.jetty.server.ServerConnector$ServerConnectorManager.newConnection(ServerConnector.java:401)
    at org.eclipse.jetty.io.SelectorManager$ManagedSelector.createEndPoint(SelectorManager.java:575)
    at org.eclipse.jetty.io.SelectorManager$ManagedSelector.access$500(SelectorManager.java:318)
    at org.eclipse.jetty.io.SelectorManager$ManagedSelector$Accept.run(SelectorManager.java:699)
    at org.eclipse.jetty.io.SelectorManager$ManagedSelector.runChange(SelectorManager.java:407)
    at org.eclipse.jetty.io.SelectorManager$ManagedSelector.runChanges(SelectorManager.java:396)
    at org.eclipse.jetty.io.SelectorManager$ManagedSelector.processChanges(SelectorManager.java:479)
    at org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:440)
    at org.eclipse.jetty.io.SelectorManager$ManagedSelector.run(SelectorManager.java:420)
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596)
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527)
    at java.lang.Thread.run(Thread.java:722)

すべてをjetty.xmlに入れました。これが私の構成です。

<New id="sslContextFactory" class="org.eclipse.jetty.util.ssl.SslContextFactory">
    <Set name="KeyStorePath">
        <Property name="jetty.home" default="." />/<Property name="jetty.keystore" default="etc/keystore"/>
    </Set>
    <Set name="KeyStorePassword">
        <Property name="jetty.keystore.password" default="OBF:password"/>
    </Set>
    <Set name="KeyManagerPassword">
        <Property name="jetty.keymanager.password" default="OBF:password"/>
    </Set>
    <Set name="TrustStorePath">
        <Property name="jetty.home" default="." />/<Property name="jetty.truststore" default="etc/keystore"/>
    </Set>
    <Set name="TrustStorePassword">
        <Property name="jetty.truststore.password" default="OBF:password"/>
    </Set>
    <Set name="EndpointIdentificationAlgorithm"/>
    <Set name="ExcludeCipherSuites">
        <Array type="String">
            <Item>SSL_RSA_WITH_DES_CBC_SHA</Item>
            <Item>SSL_DHE_RSA_WITH_DES_CBC_SHA</Item>
            <Item>SSL_DHE_DSS_WITH_DES_CBC_SHA</Item>
            <Item>SSL_RSA_EXPORT_WITH_RC4_40_MD5</Item>
            <Item>SSL_RSA_EXPORT_WITH_DES40_CBC_SHA</Item>
            <Item>SSL_DHE_RSA_EXPORT_WITH_DES40_CBC_SHA</Item>
            <Item>SSL_DHE_DSS_EXPORT_WITH_DES40_CBC_SHA</Item>
        </Array>
    </Set>
</New>
<Call id="sslConnector" name="addConnector">
    <Arg>
        <New class="org.eclipse.jetty.server.ServerConnector">
            <Arg name="server">
                <Ref refid="Server" />
            </Arg>
            <Arg name="factories">
                <Array type="org.eclipse.jetty.server.ConnectionFactory">
                    <Item>
                        <New class="org.eclipse.jetty.server.SslConnectionFactory">
                            <Arg name="next">http/1.1</Arg>
                            <Arg name="sslContextFactory">
                                <Ref refid="sslContextFactory"/>
                            </Arg>
                        </New>
                    </Item>
                    <Item>
                        <New class="org.eclipse.jetty.server.HttpConnectionFactory">
                            <Arg name="config">
                                <Ref refid="tlsHttpConfig"/>
                            </Arg>
                        </New>
                    </Item>
                </Array>
            </Arg>
            <Set name="host">
                <Property name="jetty.host" />
            </Set>
            <Set name="port">
                <Property name="jetty.tls.port" default="8443" />
            </Set>
            <Set name="idleTimeout">30000</Set>
        </New>
    </Arg>
</Call>

次に、SSLなしで行ったことはすべてjettyで機能するはずですか? 私のサーブレットとソケット?

みんなありがとう

4

2 に答える 2

1

実際、私はバージョン 9.0.4 のライブラリを使用して Jetty 9.0.3 を使用していました。サーバーを 9.0.4 にアップグレードしたところ、動作するようになりました!

于 2013-07-10T13:53:46.227 に答える
1

私は同じ問題を抱えていました(jetty 9.0.4で)。9.0.4 バージョンのすべてのライブラリと、エラーが推定されます。

例を掘り下げた後; この突堤の構成例に出会いました。jetty-ssl.xml ファイルを見ると、次のコードが表示されます。

    <!-- =========================================================== -->
  <!-- Create a TLS specific HttpConfiguration based on the        -->
  <!-- common HttpConfiguration defined in jetty.xml               -->
  <!-- Add a SecureRequestCustomizer to extract certificate and    -->
  <!-- session information                                         -->
  <!-- =========================================================== -->
  <New id="sslHttpConfig" class="org.eclipse.jetty.server.HttpConfiguration">
    <Arg><Ref refid="httpConfig"/></Arg>
    <Call name="addCustomizer">
      <Arg><New class="org.eclipse.jetty.server.SecureRequestCustomizer"/></Arg>
    </Call>
  </New>

これをxmlファイルに追加すると、すべてが機能するはずです。

于 2013-08-15T12:38:44.857 に答える