NIO+SSL 服务端报no cipher suites in common

该博客主要讨论了在Java NIO结合SSL实现服务端时遇到的错误——'no cipher suites in common'。作者通过分享服务端代码,展示了如何配置和初始化SSLContext,以及在处理SSL握手时的问题。文章中提到,客户端连接时,由于加密套件不匹配导致SSL握手失败,服务端报错并关闭连接。博客旨在寻求问题的解决办法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

每次客户端一连,服务端就报javax.net.ssl.SSLHandshakeException: no cipher suites in common,连接就断了,求解释

服务端代码如下:

package com.test.niossl;

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.InetSocketAddress;
import java.net.ServerSocket;
import java.nio.ByteBuffer;
import java.nio.channels.SelectionKey;
import java.nio.channels.Selector;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
import java.security.KeyStore;
import java.util.Iterator;

import javax.net.ssl.KeyManagerFactory;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLEngine;
import javax.net.ssl.SSLEngineResult;
import javax.net.ssl.TrustManagerFactory;
import javax.net.ssl.SSLEngineResult.HandshakeStatus;
import javax.net.ssl.SSLEngineResult.Status;
import javax.net.ssl.SSLSession;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.alibaba.fastjson.JSONObject;

public class SSLHandshakeServer {
    
    private static Logger logger = LoggerFactory.getLogger(SSLHandshakeServer.class);
    
    private SocketChannel sc;
    private SSLEngine sslEngine;
    private Selector selector;
    
    private ByteBuffer myNetData;
    private ByteBuffer myAppData;
    private ByteBuffer peerNetData;
    private ByteBuffer peerAppData;
    
    private ByteBuffer dummy = ByteBuffer.allocate(1000);
    
    private HandshakeStatus hsStatus;
    private Status status;
    
    public void run() throws Exception{
        char[] password = "1234kp".toCharArray();
        KeyStore keyStore = KeyStore.getInstance("JKS");
        InputStream in = this.getClass().getResourceAsStream("D:\\Ss_myeclipse_workspce\\test2\\src\\main\\resources\\certificate/server.jks");
        keyStore.load(in, password);
        KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");
        kmf.init(keyStore, password);
        
        KeyStore trustStore = KeyStore.getInstance("JKS");
        trustStore.load(new FileInputStream("D:\\Ss_myeclipse_workspce\\test2\\src\\main\\resources\\certificate/serverTrust.jks"), 
                "1234sp".toCharArray());
        TrustManagerFactory tmf = TrustManagerFactory.getInstance("SunX509");
        tmf.init(trustStore);

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值