我在书上找了一个安全服务器和安全客户端的程序:
代码是这样的,安全客户端:import java.io.*;
import java.net.Socket;import javax.net.ssl.SSLSocket;
import javax.net.ssl.SSLSocketFactory;
public class Client {
private String host = "localhost";
private int port = 8000;
private SSLSocket socket;

public Client()throws IOException{
SSLSocketFactory factory = (SSLSocketFactory)SSLSocketFactory.getDefault();
socket = (SSLSocket)factory.createSocket(host, port);
String[] supported = socket.getSupportedCipherSuites();
socket.setEnabledCipherSuites(supported);
System.out.println(socket.getUseClientMode()?"client":"server");
}
public static void main (String args[])throws IOException{
new Client().talk();
}

private PrintWriter getWriter(Socket socket)throws IOException{
OutputStream socketOut = socket.getOutputStream();
return new PrintWriter(socketOut, true);
}
private BufferedReader getReader(Socket socket)throws IOException{
InputStream socketIn = socket.getInputStream();
return new BufferedReader(new InputStreamReader(socketIn));
}
public void talk()throws IOException{
try{
BufferedReader br = getReader(socket);
PrintWriter pw = getWriter(socket);
BufferedReader localReader = new BufferedReader(new InputStreamReader(System.in));
String msg = null;
while((msg = localReader.readLine()) != null){
pw.println(msg);
System.out.println(br.readLine());
if(msg.equalsIgnoreCase("bye"))
break;
}
}
catch(IOException e){}
finally{
try{
socket.close();
}
catch(IOException e){}
}
}
}
安全服务器:import java.io.*;
import java.net.Socket;
import java.security.*;import javax.net.ssl.*;
public class EchoServer {
private int port = 8000;
private SSLServerSocket serverSocket;

public EchoServer() throws Exception{
SSLContext context = createSSLContext();
SSLServerSocketFactory factory = context.getServerSocketFactory();
serverSocket = (SSLServerSocket)factory.createServerSocket(port);
System.out.println("Server start!");
System.out.println(serverSocket.getUseClientMode()?"client mode":"server mode");
System.out.println(serverSocket.getNeedClientAuth()?"need":"needn't");

String [] supported = serverSocket.getSupportedCipherSuites();
serverSocket.setEnabledCipherSuites(supported);
}


public SSLContext createSSLContext() throws Exception{
String keyStoreFile = "jnp3e.keys";
String passphrase = "2andnotafnord";
KeyStore ks = KeyStore.getInstance("JKS");
char [] password = passphrase.toCharArray();
ks.load(new FileInputStream(keyStoreFile), password);
KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");
kmf.init(ks, password);


SSLContext sslContext = SSLContext.getInstance("SSL");
sslContext.init(kmf.getKeyManagers(), null, null);

//String trustStoreFile = "Client.keys";
//KeyStore ts = KeyStore.getInstance("JKS");
//ts.load(new FileInputStream(trustStoreFile),password);
//TrustManagerFactory tmf = TrustManagerFactory.getInstance("SunX509");
//tmf.init(ts);
    //sslContext.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null);

return sslContext;
}

public String echo(String msg){
return "echo:" + msg;
}

private PrintWriter getWriter (Socket socket) throws IOException{
OutputStream socketOut = socket.getOutputStream();
return new PrintWriter(socketOut, true);
}

private BufferedReader getReader(Socket socket) throws IOException{
InputStream socketIn = socket.getInputStream();
return new BufferedReader(new InputStreamReader(socketIn));
}

public void service(){
while(true){
Socket socket = null;
try{
socket = serverSocket.accept();
System.out.println("New connection accepted" + socket.getInetAddress() + ":" + socket.getPort());
BufferedReader br = getReader(socket);
PrintWriter pw = getWriter(socket);

String msg = null;
while((msg = br.readLine()) != null){
System.out.println(msg);
pw.println(echo(msg));
if(msg.equals("bye"))
break;
}
}
catch(IOException e){
e.printStackTrace();
}finally{
try{
if(socket != null)
socket.close();
}catch (IOException e){
e.printStackTrace();
}
}
}
} public static void main (String args[])throws Exception{
new EchoServer().service();
}
}
用的是eclipse,运行的时候客户端能连上服务器,但是发送信息的时候就会报错,说Unknown Certificate。但是如果用dos运行客户端,输入java -Djavax.net.ssl.trustStore=jnp3e.keys Client就对了,我想问问各位大牛这是什么原因,我怎么样才能在eclipse下正确的运行客户端呢,求各位大牛帮助啊!!!急!!!