SpringBoot2.x配置HTTPS訪問的過程
SpringBoot2.x配置HTTPS訪問,總體上可以分為兩大步:
- 生成SSL證書
- 配置HTTPS訪問
一.生成SSL證書
取得SSL證書的方法有:
(1)阿里云購買免費的ssl證書
(2)用命令生成ssl證書
因為在阿里云購買后需要填寫域名,所以這里選擇第(2)種方式:用命令生成ssl證書
1.新建一個證書目錄,例如D:\sslca
打開cmd命令窗口,切換到D:\sslca
- C:\Users\Administrator>d:
- D:\>cd D:\sslca
- D:\sslca>
2.命令生成證書
keytool -genkey -alias tomcat -keypass 12345678 -keyalg RSA -keysize 2048 -validity 365 -keystore ./tomcat.keystore -storepass 12345678
過程如下:提示問題的回答可以任意填寫
D:\sslca>keytool -genkey -alias tomcat -keypass 12345678 -keyalg RSA -keysize 2048 -validity 365 -keystore ./tomcat.keystore -storepass 12345678 您的名字與姓氏是什么? [Unknown]: liang 您的組織單位名稱是什么? [Unknown]: aa 您的組織名稱是什么? [Unknown]: bb 您所在的城市或區(qū)域名稱是什么? [Unknown]: cc 您所在的省/市/自治區(qū)名稱是什么? [Unknown]: dd 該單位的雙字母國家/地區(qū)代碼是什么? [Unknown]: Ch CN=liang, OU=aa, O=bb, L=cc, ST=dd, C=Ch是否正確? [否]: y Warning: JKS 密鑰庫使用專用格式。建議使用 "keytool -importkeystore -srckeystore ./tomcat.keystore -destkeystore ./tomcat.keystore -deststoretype pkcs12" 遷移到行業(yè)標(biāo)準(zhǔn)格式 PKCS12。 D:\sslca>
在D:\sslca生成了tomcat.keystore文件:

3.生成客戶端證書
keytool -genkey -alias client -keypass 12345678 -keyalg RSA -keysize 2048 -validity 365 -storetype PKCS12 -keystore ./client.p12 -storepass 12345678
過程如下:提示信息的回答可以任意填寫
您的名字與姓氏是什么? [Unknown]: aa 您的組織單位名稱是什么? [Unknown]: bb 您的組織名稱是什么? [Unknown]: cc 您所在的城市或區(qū)域名稱是什么? [Unknown]: dd 您所在的省/市/自治區(qū)名稱是什么? [Unknown]: Ch 該單位的雙字母國家/地區(qū)代碼是什么? [Unknown]: Ch CN=aa, OU=bb, O=cc, L=dd, ST=Ch, C=Ch是否正確? [否]: y
在D:\sslca生成了client.p12文件:

二.配置HTTPS訪問
1.打開已有的SpringBoot工程
2.將證書文件:client.p12復(fù)制到resources目錄下

3.修改application.yml
server:
port: 8443 #注意,這里是https訪問的的端口號
ssl:
key-store: file:F:\Study\mywebsite\websiteback\src\main\resources\client.p12
key-store-password: 12345678
key-store-type: PKCS12
key-alias: client注意:key-store:值的路徑要注意按實際修改
4.修改啟動類
添加servletContainer()和initiateHttpConnector()兩個方法,完整代碼如下:
package com.jipson.websiteback;
import org.apache.catalina.Context;
import org.apache.catalina.connector.Connector;
import org.apache.tomcat.util.descriptor.web.SecurityCollection;
import org.apache.tomcat.util.descriptor.web.SecurityConstraint;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;
import org.springframework.context.annotation.Bean;
@SpringBootApplication
@MapperScan({"com.jipson.websiteback.dao"})
public class WebsitebackApplication {
public static void main(String[] args) {
SpringApplication.run(WebsitebackApplication.class, args);
}
@Bean
public TomcatServletWebServerFactory servletContainer() { //springboot2 新變化
TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory() {
@Override
protected void postProcessContext(Context context) {
SecurityConstraint securityConstraint = new SecurityConstraint();
securityConstraint.setUserConstraint("CONFIDENTIAL");
SecurityCollection collection = new SecurityCollection();
collection.addPattern("/*");
securityConstraint.addCollection(collection);
context.addConstraint(securityConstraint);
}
};
tomcat.addAdditionalTomcatConnectors(initiateHttpConnector());
return tomcat;
}
private Connector initiateHttpConnector() {
Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
connector.setScheme("http");
connector.setPort(8080);
connector.setSecure(false);
connector.setRedirectPort(8443);
return connector;
}
}5.啟動Springboot項目
6.瀏覽器訪問 https://localhost:8443/getAllUser

可以看到用https訪問成功了!
問題:此方式只支持https訪問,訪問http端口會自動轉(zhuǎn)到https方式訪問。如果項目只需要https訪問這樣配置已經(jīng)夠用,如果需要http和https方式同時訪問的話,繼續(xù)看如下配置。
配置既能支持https又能支持http的方式如下:
1.修改application.yml,添加http port配置
server:
port: 8443 #注意,這里是https訪問的的端口號
http:
port: 8081
ssl:
key-store: file:F:\Study\mywebsite\websiteback\src\main\resources\client.p12
key-store-password: 12345678
key-store-type: PKCS12
key-alias: client2.還原啟動類(WebsitebackApplication.java):刪除或注釋掉servletContainer和initiateHttpConnector方法
3.添加配置類TomcatConfig.java
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;
@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;
}
}這樣配置就可以用http和https都能訪問了
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot 整合Redisson重寫cacheName支持多參數(shù)的案例代碼
這篇文章主要介紹了SpringBoot 整合Redisson重寫cacheName支持多參數(shù),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-01-01
java long轉(zhuǎn)String +Codeforces110A案例
這篇文章主要介紹了java long轉(zhuǎn)String +Codeforces110A案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
springboot如何開啟緩存@EnableCaching(使用redis)
在Spring Boot項目中集成Redis主要包括添加依賴到pom.xml、配置application.yml中的Redis連接參數(shù)、編寫配置類、在啟動類上添加@EnableCaching注解以及測試接口的查詢和緩存驗證等步驟,首先,需要在pom.xml中添加spring-boot-starter-data-redis依賴2024-11-11
Java平臺調(diào)試體系原理分析和實踐整理 遠(yuǎn)程Debug
這篇文章主要介紹了Java平臺調(diào)試體系原理分析和實踐整理 遠(yuǎn)程Debug,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
Java圖形界面之JFrame,JLabel,JButton詳解
這篇文章主要介紹了Java圖形界面之JFrame、JLabel、JButton詳解,文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)java的小伙伴們有非常好的幫助,需要的朋友可以參考下2021-04-04
MyBatis-Plus非表字段的三種處理方法小結(jié)
這篇文章主要介紹了MyBatis-Plus非表字段的三種處理方法小結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08
Java(SpringBoot)項目打包(構(gòu)建)成Docker鏡像的幾種常見方式
在對Spring Boot應(yīng)用程序進行Docker化時,為應(yīng)用程序選擇正確的基礎(chǔ)鏡像非常重要,下面這篇文章主要給大家介紹了關(guān)于Java(SpringBoot)項目打包(構(gòu)建)成Docker鏡像的幾種常見方式,需要的朋友可以參考下2023-12-12
Spring Boot數(shù)據(jù)庫鏈接池配置方法
這篇文章主要介紹了Spring Boot數(shù)據(jù)庫鏈接池配置方法,需要的朋友可以參考下2017-04-04

