4
回答
MINA和SSL结合的问题?
终于搞明白,存储TCO原来是这样算的>>>   
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组合到一起呀!


希望能帮我解决,谢谢大家了


举报
erwei1983
发帖于7年前 4回/2K+阅
顶部