栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Netty笔记----Https请求

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Netty笔记----Https请求

Netty发送https请求时,需要SSL认证

1.首先创建jks认证证书,认证方式:

通过KeyTool 使用以下命令生成

keytool -genkeypair -alias yourAlias -keypass yourPassword -keyalg RSA -keysize 2048 -validity 365 -keystore filePath -storepass yourPassword

原文链接:

https://www.136.la/jingpin/show-169264.htmlhttps://www.136.la/jingpin/show-169264.html

2.读取jks文件的工具类

public class SslUtil {

    private static volatile SSLContext sslContext = null;
    
    public static SSLContext createSSLContext(String type ,String fileName ,String password) throws Exception {
        if(null == sslContext){
            synchronized (SslUtil.class) {
                if(null == sslContext){
                    // 支持JKS、PKCS12(我们项目中用的是阿里云免费申请的证书,下载tomcat解压后的pfx文件,对应PKCS12)
                    KeyStore ks = KeyStore.getInstance(type);
                    // 证书存放地址
                    InputStream ksInputStream = SslUtil.class.getClassLoader().getResourceAsStream(fileName);
                    ks.load(ksInputStream, password.toCharArray());
                    KeyManagerFactory kmf = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm());
                    kmf.init(ks, password.toCharArray());
                    sslContext = SSLContext.getInstance("TLS");
                    sslContext.init(kmf.getKeyManagers(), null, null);
                }
            }
        }
        return sslContext;
    }
}

3.netty开启ssl验证

 SSLContext sslContext = SslUtil.createSSLContext("JKS","xxx.jks","xxxxx");
 SSLEngine sslEngine = sslContext.createSSLEngine();
 //仅服务端验证
 sslEngine.setUseClientMode(true);
 sslEngine.setNeedClientAuth(false); //不需要验证客户端
 ch.pipeline().addLast("SSL",new SslHandler(sslEngine));

4.以上步骤完成即可完成https请求发送

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/880806.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号