2014-09-01 65 views
0

我试图在IPhone应用程序与Java SSLServerSocket之间建立SSL连接。 我的Java服务器看起来就像是:IPhone应用程序与Java ServerSocket之间的SSL连接

SSLServerSocketFactory ssf = null; 
    try { 
     // set up key manager to do server authentication 
     SSLContext ctx; 
     KeyManagerFactory kmf; 
     KeyStore ks; 
     char[] passphrase = "passphrase".toCharArray(); 

     ctx = SSLContext.getInstance("TLS"); 
     kmf = KeyManagerFactory.getInstance("SunX509"); 
     ks = KeyStore.getInstance("JKS"); 

     ks.load(new FileInputStream("fsKeystore"), passphrase); 
     kmf.init(ks, passphrase); 
     ctx.init(kmf.getKeyManagers(), null, null); 

     ssf = ctx.getServerSocketFactory(); 

     System.out.println("Waiting for Connection"); 
     SSLServerSocket sslsocketServer = (SSLServerSocket) ssf.createServerSocket(9999); 
     SSLSocket sslsocket = (SSLSocket) sslsocketServer.accept(); 
     sslsocket.addHandshakeCompletedListener(new HandshakeCompletedListener() { 

      @Override 
      public void handshakeCompleted(HandshakeCompletedEvent arg0) { 
       System.out.println("Handshake finished"); 
      } 
     }); 
     InputStream inputstream = sslsocket.getInputStream(); 
     InputStreamReader inputstreamreader = new InputStreamReader(inputstream); 
     BufferedReader bufferedreader; 
     bufferedreader = new BufferedReader(inputstreamreader); 

     String string = ""; 
     while ((string = bufferedreader.readLine()) != null) { 
      string = bufferedreader.readLine(); 
      System.out.println(System.currentTimeMillis()); 
      System.out.println(string); 
      System.out.flush(); 
     } 
    } catch (Exception e) { 
     e.printStackTrace(); 
    } 

在Objective-C我已经实现这个解决方案:

-(id) initWithUrl: (NSString*) host onPort: (NSInteger) port withDelegate:(id<TCPDelegate>) delegate{ 
self = [super init]; 
if(self){ 

    //initTimer 
    sendBuffer=[[NSMutableArray alloc]init]; 
    NSTimer *timer =[NSTimer scheduledTimerWithTimeInterval:0.2 target:self selector:@selector(timerTick:) userInfo:nil repeats:YES]; 
    NSRunLoop *runloop = [NSRunLoop currentRunLoop]; 
    [runloop addTimer:timer forMode:NSDefaultRunLoopMode]; 

    del=delegate; 
    CFReadStreamRef readStream; 
    CFWriteStreamRef writeStream; 

    CFStreamCreatePairWithSocketToHost(NULL,(__bridge CFStringRef)host, port,&readStream,&writeStream); 

    iStream = (__bridge_transfer NSInputStream *)readStream; 
    oStream = (__bridge_transfer NSOutputStream *)writeStream; 

    [iStream setDelegate:self]; 
    [oStream setDelegate:self]; 

    [iStream scheduleInRunLoop:[NSRunLoop currentRunLoop] forMode:NSDefaultRunLoopMode]; 
    [oStream scheduleInRunLoop:[NSRunLoop currentRunLoop] forMode:NSDefaultRunLoopMode]; 


    [iStream open]; 
    [oStream open]; 

    [iStream setProperty:NSStreamSocketSecurityLevelNegotiatedSSL 
        forKey:NSStreamSocketSecurityLevelKey]; 
    [oStream setProperty:NSStreamSocketSecurityLevelNegotiatedSSL 
        forKey:NSStreamSocketSecurityLevelKey]; 
    line = @""; 
} 
return self; 
} 

在iPhone App我得到

CFNetwork的SSLHandshake失败(-9807 )

任何想法问题可能是什么?

+0

加密是你永远不应该做的事情之一;两端使用标准库。 – chrylis 2014-09-01 07:59:17

+0

你能否更清楚地描述一下?我使用哪些不属于标准库的部分? – user2071938 2014-09-01 08:00:22

+0

你在这个SSL套接字上运行什么?现在,它几乎总是HTTP,并且我认为iOS HTTP客户端库可以像Java中的“HttpURLConnection”一样处理SSL。 – chrylis 2014-09-01 08:18:53

回答

相关问题