springboot https服务配置

说明

能够使用到https服务,一般是web服务器或者网关服务器。

步骤1 生成证书文件

此处用的是自签名证书。

JDK中keytool是一个证书管理工具,可以生成自签名证书。(找不到keytool命令的先去配置java环境)
keytool -genkey -alias worktool -keyalg RSA -keystore ssl.keystore

输入密钥库口令:(Pass0rd)
再次输入新口令:
您的名字与姓氏是什么?
  [Unknown]:  net
您的组织单位名称是什么?
  [Unknown]:  net
您的组织名称是什么?
  [Unknown]:  net
您所在的城市或区域名称是什么?
  [Unknown]:  WUHAN
您所在的省/市/自治区名称是什么?
  [Unknown]:  HUBEI
该单位的双字母国家/地区代码是什么?
  [Unknown]:  CN
CN=wd, OU=wd, O=wd, L=SHANGHAI, ST=SHANGHAI, C=CN是否正确?
  [否]:  y

生成p12证书的方法


keytool支持交互的方式提供证书信息。要生成一个p12证书,必须了解这样几个参数:

-genkeypair 生成证书
-keystore 生成证书的路径和文件名
-storetype 生成的证书类型,使用pkcs12指定p12格式证书
-validity 有效期的天数,用一个足够大的值跳转到2034年
下面是一个例子:

keytool -genkeypair -keystore ssl.p12 -storetype pkcs12 -validity 365
输入密钥库口令:(Pass0rd)
再次输入新口令:
您的名字与姓氏是什么?
  [Unknown]:  net
您的组织单位名称是什么?
  [Unknown]:  net
您的组织名称是什么?
  [Unknown]:  net
您所在的城市或区域名称是什么?
  [Unknown]:  WUHAN
您所在的省/市/自治区名称是什么?
  [Unknown]:  HUBEI
该单位的双字母国家/地区代码是什么?
  [Unknown]:  CN
CN=wd, OU=wd, O=wd, L=SHANGHAI, ST=SHANGHAI, C=CN是否正确?
  [否]:  y
还是用上面的方法验证一下证书的有效期:

keytool -list -keystore ssl.p12 -storetype pkcs12 -v
输入密钥库口令:

密钥库类型: PKCS12
密钥库提供方: SunJSSE

您的密钥库包含 1 个条目

别名: mykey
创建日期: 2012-9-27
条目类型: PrivateKeyEntry
证书链长度: 1
证书[1]:
所有者: CN=.net, OU=.net, O=.net, L=WUHAN, ST=HUBEI, C=CN
发布者: CN=.net, OU=.net, O=.net, L=WUHAN, ST=HUBEI, C=CN
序列号: 1faa29fb
有效期开始日期: Thu Sep 27 18:23:31 CST 2012, 截止日期: Thu Oct 12 18:23:31 CST 2034
证书指纹:
         MD5: F8:00:9C:3B:7B:4F:F2:9D:A3:B6:3F:E9:78:2D:9A:46
         SHA1: 10:21:FF:B3:DE:3F:D4:0D:44:F7:D1:07:6A:3F:09:D8:36:B9:D1:21
         SHA256: AB:8A:09:5B:69:1F:95:A5:94:F7:60:F6:D0:81:8A:1D:23:42:94:3C:96:D3:04:AD:C9:59:05:14:2E:B6:6D:79
         签名算法名称: SHA1withDSA
         版本: 3

步骤2 先设置配置文件 application.yml

server:
  port: 9001
#  session:
#    timeout: 6000

system:
  ssl:
    # 是否开启https
    enable: true
    # https的端口
    port: 9443
    # 证书文件
    key-store: ssl.keystore
    # 生成的密钥
    key-store-password: Pass0Rd
    # 证书类型
    keyStoreType: JKS
    # 证书文件存放位置
    key-store-path: /usr/local/bin
    # 是否http自动跳转https
    redirect_https: true

步骤3 通过注册Bean的方式配置ssl

@ConditionalOnExpression(value = "${system.ssl.enable:false}")
@Configuration
@Slf4j
public class CustomServerSSLConfiguration {

    @Value("${server.port}")
    private Integer serverPort;

    @Value("${system.ssl.port}")
    private Integer tomcatSSLPort;

    @Value("${system.ssl.key-store}")
    private String tomcatSSLKeyStore;

    @Value("${system.ssl.key-store-password}")
    private String keystorePassword;

    @Value("${system.ssl.keyStoreType}")
    private String keystoreType;

    @Value("${system.ssl.key-store-path}")
    private String keystorePath;

    @Value("${system.ssl.redirect_https}")
    private Boolean redirectHttps;

    /**
    *  1.5.x以下版本配置
    * @param
    * @return
    * @throws
    */
    @Bean
    public EmbeddedServletContainerFactory servletContainer() {
        TomcatEmbeddedServletContainerFactory tomcat = new TomcatEmbeddedServletContainerFactory();
        tomcat.addAdditionalTomcatConnectors(createSslConnector()); // 添加https

        return tomcat;
    }


    // 配置https
    private Connector createSslConnector() {
        Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
        Http11NioProtocol protocol = (Http11NioProtocol) connector.getProtocolHandler();
//        BufferedReader bre = null;
//        OutputStreamWriter pw = null;// 定义一个流
        try {

            File file = new ClassPathResource(tomcatSSLKeyStore).getFile();
            // log.info("keystore文件路径={},文件名={}", file.getAbsolutePath(),tomcatSSLKeyStore);

            connector.setPort(tomcatSSLPort);
            connector.setSecure(true);
            connector.setScheme("https");

            protocol.setSSLEnabled(true);
//            protocol.setSSLProtocol("TLS");

            protocol.setKeystoreFile(file.getAbsolutePath());
            protocol.setKeystoreType(keystoreType);
            protocol.setKeystorePass(keystorePassword);
            protocol.setKeyPass(keystorePassword);
            return connector;
        } catch (IOException ex) {
           try {
               ClassLoader classloader = Thread.currentThread().getContextClassLoader();
               InputStream stream = classloader.getResourceAsStream(tomcatSSLKeyStore);

               File file = new File(keystorePath);
               if (!file.exists()){
                   // log.info("===================文件不存在,进行创建");
                   file.mkdirs();
               }
               File file1 = new File(keystorePath+"/"+tomcatSSLKeyStore);
               if (!file1.exists()){
                   // log.info("===================文件不存在,创建文件");
                   file1.createNewFile();
               }
//                bre = new BufferedReader(new InputStreamReader(stream, "UTF-8"));
//                pw = new OutputStreamWriter(new FileOutputStream(tomcatSSLKeyStore);

               FileOutputStream fos = new FileOutputStream(file1);
               byte[] b = new byte[1024];
               while ((stream.read(b)) != -1) {
                   fos.write(b);
               }
               stream.close();
               fos.close();
               // log.info("keystore文件路径={},文件名={}", file1.getAbsolutePath(),tomcatSSLKeyStore);

               connector.setPort(tomcatSSLPort);
               connector.setSecure(true);
               connector.setScheme("https");

               protocol.setSSLEnabled(true);
//            protocol.setSSLProtocol("TLS");

               protocol.setKeystoreFile(file1.getAbsolutePath());
               protocol.setKeystoreType(keystoreType);
               protocol.setKeystorePass(keystorePassword);
               protocol.setKeyPass(keystorePassword);
               return connector;
           }catch (IOException ex1){
               log.error("ssl.keystore文件不存在,请放入项目的src/main/resources下面。");
           }
        }
        return null;
    }
}

更多,请关注:
springboot 技术实践总结

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容