SpringBoot配置SSL同时支持http和https访问实现

作者:michael.csdn 时间:2023-04-25 19:42:45 

传输层安全性协议(英语:Transport Layer Security,缩写作 TLS),及其前身安全套接层(Secure Sockets Layer,缩写作 SSL)是一种安全协议,目的是为互联网通信,提供安全及数据完整性保障。

SSL包含记录层(Record Layer)和传输层,记录层协议确定传输层数据的封装格式。传输层安全协议使用X.509认证,之后利用非对称加密演算来对通信方做身份认证,之后交换对称密钥作为会谈密钥(Session key)。

这个会谈密钥是用来将通信两方交换的数据做加密,保证两个应用间通信的保密性和可靠性,使客户与服务器应用之间的通信不被攻击者窃听。

第一步:生成证书

在配置 TLS/SSL 之前需要先拿到相应的签名证书,配置了JAVA开发环境,可以使用 Java 下面的 Keytool 来生成证书,打开控制台输入:
keytool -genkey -alias michaelSpica -storetype PKCS12 -keyalg RSA -keysize 2048 -keystore E:\Temp\michaelSpica.p12 -validity 3650

  • -alias 别名(可随便取)

  • -storetype 指定密钥仓库类型

  • -keyalg 生证书的算法名称,RSA是一种非对称加密算法

  • -keysize 证书大小

  • -keystore 生成的证书文件的存储路径(相对路径或绝对路径)

  • -validity 证书的有效期

如图:

SpringBoot配置SSL同时支持http和https访问实现

注:正式环境中请填写标准值

第二步:获取证书

根据路径找到生成好的证书,把证书复制到项目里,如图:

SpringBoot配置SSL同时支持http和https访问实现

第三步:增加SSL配置

application.yml 中添加如下配置,如图:

SpringBoot配置SSL同时支持http和https访问实现

第四步:配置https访问

添加Spring Boot启动时,读取配置信息,如

(注:请添加必要的jar)

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
package com.michael.protocol.config;

import org.apache.catalina.connector.Connector;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;
import org.springframework.boot.web.servlet.server.ServletWebServerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
* Created by michael on 2019/2/23.
*/
@Configuration
public class TomcatConfig {

@Value("${server.http.port}")
   private int httpPort;

@Bean
   public ServletWebServerFactory servletContainer() {
       TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory();
       tomcat.addAdditionalTomcatConnectors(createStandardConnector()); // 添加http
       return tomcat;
   }

private Connector createStandardConnector() {
       Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
       connector.setPort(httpPort);
       return connector;
   }
}

注:这是 spring boot 2.0.X 版本的

至此,所有工作已经完成,启动项目,如:

SpringBoot配置SSL同时支持http和https访问实现

可以看到两个端口,说明已经成功,即可通过以下两种方式进行访问:
https://localhost:443
http://localhost:80

来源:https://blog.csdn.net/qq_38288606/article/details/89478353

标签:SpringBoot,SSL,http,https
0
投稿

猜你喜欢

  • C#实现自由组合本地缓存、分布式缓存和数据查询

    2021-06-13 00:56:11
  • C# 分支与循环介绍

    2022-10-26 13:50:02
  • mybatis批量添加,批量更新之前如何判断是否已经存在

    2022-01-03 20:33:38
  • Java ArrayList实现班级信息管理系统

    2023-09-17 15:15:25
  • 解决IDEA springboot"spring-boot-maven-plugin"报红问题

    2023-08-15 21:29:19
  • C#中static静态变量的用法实例

    2022-12-16 07:47:44
  • c#只读字段和常量的区别,以及静态构造函数的使用实例

    2023-10-31 09:52:20
  • 详解Spark Sql在UDF中如何引用外部数据

    2021-08-17 14:51:17
  • Android Studio kotlin生成编辑类注释代码

    2023-06-16 12:03:20
  • 深入浅析TomCat Session管理分析

    2022-12-16 02:44:16
  • java中LinkedBlockingQueue与ArrayBlockingQueue的异同

    2023-08-19 02:56:49
  • 浅谈Spring Data如何简化数据操作的方法

    2023-04-19 04:50:08
  • java 获取对象中为null的字段实例代码

    2023-08-28 06:32:53
  • Kotlin LinearLayout与RelativeLayout布局使用详解

    2021-12-06 02:07:30
  • Android使用 Retrofit 2.X 上传多文件和多表单示例

    2023-08-06 03:48:25
  • 基于C#实现的端口扫描器实例代码

    2022-04-29 20:21:56
  • Android画板开发之添加背景和保存画板内容为图片

    2022-05-30 04:01:37
  • 浅谈java多态的实现主要体现在哪些方面

    2023-08-17 07:41:32
  • c#中的常用ToString()方法总结

    2023-01-13 01:18:30
  • Unity 从Resources中动态加载Sprite图片的操作

    2023-08-26 11:37:18
  • asp之家 软件编程 m.aspxhome.com