我将嵌入式Jetty的Web应用程序从7迁移到9.3.2,因此需要稍微更新代码。应用程序本身有许多为其编写的连接器,用于Web UI,API端点以及通过智能卡对Web界面进行身份验证。实现它的连接器方法如下实现(对于Jetty 7)。
private Connector createSmartCardConnector() {
SslContextFactory sslContextFactory = createSslContextFactory(smartCardUiKeyStoreFile);
LOG.info("Using truststore file: " + trustStoreFile);
sslContextFactory.setTrustStore(trustStoreFile);
sslContextFactory.setTrustStorePassword("password");
sslContextFactory.setNeedClientAuth(true);
Connector connector = new SslSocketConnector(sslContextFactory) {
@Override public void accept(int acceptorID) throws IOException, InterruptedException {
Socket socket = _serverSocket.accept();
configure(socket);
SslConnectorEndPoint connection = new SslConnectorEndPoint(socket);
SMART_CARD_SOCKETS.add((SSLSocket) socket);
connection.dispatch();
}
};
从代码中可以明显看出,SslSocketConnector.accept()
方法被覆盖,唯一添加的部分是SMART_CARD_SOCKETS.add((SSLSocket) socket);
。 SMART_CARD_SOCKETS
是一个稍后用于销毁添加到其中的对象(套接字)的集合。我的问题是如何在Jetty 9中实现相同的功能,其中一点是当智能卡从用户的计算机中移除时,当用户试图进一步导航时,套接字将被销毁。
我试图覆盖Jetty 9中的ServerConnector.accept()
方法,但它在其中使用了私有方法,这使得这不可能。
答案 0 :(得分:0)
您想要的是HttpConfiguration.Customizer
的自定义实现。
将HttpConfiguration
添加到您感兴趣的ServerConnector
,然后每次接受都会运行。
使用SecureRequestCustomizer.java
的示例。
// Setup SSL
SslContextFactory sslContextFactory = new SslContextFactory();
sslContextFactory.setKeyStorePath("/path/to/keystore");
sslContextFactory.setKeyStorePassword("password");
sslContextFactory.setKeyManagerPassword("password");
// Setup HTTPS Configuration
HttpConfiguration httpsConf = new HttpConfiguration();
httpsConf.setSecurePort(8443);
httpsConf.setSecureScheme("https");
httpsConf.addCustomizer(new SecureRequestCustomizer()); // adds ssl info to request
// Establish the ServerConnector
ServerConnector httpsConnector = new ServerConnector(server,
new SslConnectionFactory(sslContextFactory,"http/1.1"),
new HttpConnectionFactory(httpsConf));
httpsConnector.setPort(httpsPort);
server.addConnector(httpsConnector);