MINA和SSL结合的问题?
public class ClientMain //public class ClientMain extends GenericServlet { //端口号 private static final int CONNECT_PORT = 9006; public static void main(String args[]){ SSLContext ctx = null; try { // 返回实现指定安全套接字协议的 SSLContext 对象 ctx = SSLContext.getInstance("SSL"); //生成实现指定密钥管理算法的 KeyManagerFactory 对象 KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509"); // 返回充当信任管理器工厂的 TrustManagerFactory 对象 TrustManagerFactory tmf = TrustManagerFactory.getInstance("SunX509"); KeyStore ks = KeyStore.getInstance("JKS"); KeyStore tks = KeyStore.getInstance("JKS"); ks.load(new FileInputStream("C:/testSSLGD/keystore.jks"), "888888".toCharArray()); tks.load(new FileInputStream("C:/testSSLGD/keystore.jks"), "888888".toCharArray()); //使用密钥内容源初始化此工厂 kmf.init(ks, "888888".toCharArray()); // 使用特定于提供程序的密钥内容源初始化此工厂 tmf.init(tks); ctx.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (KeyStoreException e) { e.printStackTrace(); } catch (CertificateException e) { e.printStackTrace(); } catch (UnrecoverableKeyException e) { e.printStackTrace(); } catch (KeyManagementException e) { e.printStackTrace(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } SSLFilter sslFilter = new SSLFilter(ctx); sslFilter.setUseClientMode(true); IoConnector ic = new NioSocketConnector(); ic.getSessionConfig().setReadBufferSize(10240); ic.getFilterChain().addLast("sslFilter", sslFilter); //使用字符串编码 ic.getFilterChain().addLast("codec", new ProtocolCodecFilter(new MyTextFactory())); //启动逻辑处理ClientHandler ic.setHandler(new ClientHandler()); IoSession session = null; try { //此处配置的是连接的服务器端的IP地址和端口号 ConnectFuture future = ic.connect(new InetSocketAddress("127.0.0.1",CONNECT_PORT)); future.awaitUninterruptibly();//等待连接创建完成 session = future.getSession(); session.getCloseFuture().awaitUninterruptibly();//等待连接关闭 }catch(Exception e) { e.printStackTrace(); } ic.dispose(); } } 这个怎么不能运行啊,运行后连接上服务器端后马上就关闭链路了,SSL没起作用,把ic.getFilterChain().addLast("sslFilter", sslFilter);去掉后就可以用了,但就明文的。我用另一种方法就SSL可以连接上,说明我的证书没有问题,不知道ic.getFilterChain().addLast("sslFilter", sslFilter);到底是做什么的呀,为什么加上后就不可以用了,mina到底怎么和SSL组合到一起呀! 希望能帮我解决,谢谢大家了
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
服务器端也是用mina做的吗?服务器端有没有支持SSL啊?
这篇文章可以做下参考
http://lanmh.javaeye.com/blog/216957
mina的http例子有加入ssl的哦
用的不多,学习中!