如何在 Jetty 中禁止特定的 SSL 协议



我有一个在 Debian 6.0.7 上的 Jetty 6 + Open JDK 7 上运行的 Web 应用程序。 我有一个安全要求,即在客户端启动 HTTPS 连接时接受 TLS 握手,但不接受 SSLv3.0 握手。

在我的码头上.xml我将协议设置为 TLS:

<New class="org.mortbay.jetty.security.SslSocketConnector">
    <Set name="protocol">TLS</Set>
    ...

使用此配置,Web 服务器似乎仍接受 SSLv3.0 握手。 这已经通过"sslscan"工具和运行"curl -sslv3 -kv {host}"进行了验证。

是否可以将 Jetty 配置为仅接受 TLS 握手? 如果需要,我愿意升级我的码头版本。

我找到了两个解决方案:

升级到 Jetty 9,它支持码头.xml条目:

<Arg name="sslContextFactory">
    ...
    <Set name="excludeProtocols">
      <Array type="java.lang.String">
        <Item>SSLv3</Item>
      </Array>
     </Set>

或者,使用 Jetty 6 为 SslSocketConnector 和 SSLServerSocketFactory 创建委托类:

jetty.xml:
  ...
  <New class="com.src.TlsSocketConnector">
    ...
  </New>
public class TlsSocketConnector extends SslSocketConnector  {
  @Override
  protected SSLServerSocketFactory createFactory() throws Exception {
    return new TlsServerSocketFactory( super.createFactory() );
  }
}
public class TlsServerSocketFactory extends SSLServerSocketFactory {
  private SSLServerSocketFactory delegate;
  public TlsServerSocketFactory( SSLServerSocketFactory delegate ) {
    this.delegate = delegate;
  }
  //Repeat this pattern for all createServerSocket() methods
  public ServerSocket createServerSocket() throws IOException {
    SSLServerSocket socket = (SSLServerSocket) delegate.createServerSocket();
    socket.setEnabledProtocols( new String[]{"TLSv1", "TLSv1.1", "TLSv1.2"});
    return socket;
  }
  // Directly delegated methods from SSLServerSocketFactory
  public String[] getDefaultCipherSuites() { return delegate.getDefaultCipherSuites(); }
  public String[] getSupportedCipherSuites() { return delegate.getSupportedCipherSuites(); }
}

对于 Jetty 6,您还可以创建一个覆盖的 SslSelectChannelConnector 来删除 SSLv3,如下所示:

package com.mycompany;
import java.io.IOException;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Set;
import javax.net.ssl.SSLEngine;
import org.mortbay.jetty.security.SslSelectChannelConnector;
public class SslSelectChannelConnectorNoSsl3 extends SslSelectChannelConnector {
  @Override
  protected SSLEngine createSSLEngine() throws IOException {
    SSLEngine engine = super.createSSLEngine();
    Set<String> protocols = new HashSet<String>(Arrays.asList(engine.getEnabledProtocols()));
    protocols.removeAll(Arrays.asList("SSLv2Hello","SSLv3"));
    engine.setEnabledProtocols(protocols.toArray(new String[protocols.size()]));
    return engine;
  }
}

然后在 jetty.xml 中指定该连接器,如下所示:

<Call name="addConnector">
 <Arg>
   <New class="com.mycompany.SslSelectChannelConnectorNoSsl3">
   ...
   </New>
 </Arg>
</Call>  

最新更新