SpringBoot之SSL配置(SpringBoot实战)

来源:互联网 发布:qq伪装手机型号软件 编辑:程序博客网 时间:2024/04/30 08:52

1、SSL介绍和说明

SSL的配置也是我们在实际应用中经常遇到的场景

SSL(Secure Sockets Layer,安全套接层)是为网络通信提供安全及数据完整性的一种协议,SSL在网络传输层对网络连接进行加密。SSL协议位于TCP/IP协议与各种应用层协议之间,为数据通信提供安全支持。SSL协议可以分为两层:SSL记录协议(SSL Record Protocal),它建立在可靠的传输协议(如TCP)之上,为高层协议提供数据封装、压缩、加密等基础功能的支持。SSL握手协议(SSL Handshake Protocal),它建立在SSL记录协议之上。用于在实际数据传输开始前,通信双方进行身份认证、协商加密算法、交换加密密钥等。

而在基于B/S的Web应用中,是通过HTTPS来实现SSL的。HTTPS是以安全为目标的HTTP通道,简单讲是HTTP的安全版,即在HTTP下加入SSL层,HTTPS的安全基础是SSL。

2、生成证书

使用SSL首先需要一个证书,这个证书既可以是自签名的,也可以是从SSL授权中心获得的。下面演示自授权证书的生成。

每一个JDK或JRE里面都有一个工具叫keytool,它是一个证书管理工具,可以用来生成自签名的证书。

这里写图片描述
这里写图片描述

使用CMD进入C:\Program Files\Java\jdk1.8.0_111\bin所在的目录,然后输入一下内容:

keytool -genkey -alias tomcat

这里写图片描述
接着进入当前用户目录下,发现已经生成了一个.keystore文件,这就是我们要用的证书文件,如图所示。
这里写图片描述

2.1 Spring Boot配置SSL

添加一个index.html到src/main/resources/static下,作为测试

将.keystore文件复制到项目的根目录(即pom.xml所在的位置),然后在application.properties中做SSL的配置:

#server.port = 8443#server.ssl.key-store = .keystore#server.ssl.key-store-password= 111111#server.ssl.keyStoreType= JKS#server.ssl.keyAlias: tomcat

接着再浏览器上访问:https://localhost:8443.会出现相应页面