原创: SpringBoot配置HTTPS,并实现HTTP访问自动转HTTPS访问

 

一:服务器配置成功


 

提示:

后朋友推荐用宝宝塔和https://freessl.cn申请操作
配置成功,后期进入研究

 java -jar xxx.jar --server.port=7777
不要使用,请给如下域名使用 apijob.kjfwtp.com

原创链接:https://www.cnblogs.com/asplover/p/15183103.html


二:本地配置成功,服务器没成功,先用上边一种了

参考来源: https://www.jianshu.com/p/8d4aba3b972d

 

输入如下命名时,本例选择d盘文件下新建文件keystore
即在: d:/keystore

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
Dell@zhanxuPC MINGW64 /d/keystore
$ keytool -genkey -alias tomcat -keyalg RSA -keystore ./server.keystore
输入密钥库口令:
再次输入新口令:
您的名字与姓氏是什么?
  [Unknown]:  xuZhang
您的组织单位名称是什么?
  [Unknown]:  fingerTip
您的组织名称是什么?
  [Unknown]:  fingerTip
您所在的城市或区域名称是什么?
  [Unknown]:  suqian
您所在的省/市/自治区名称是什么?
  [Unknown]:  suqianshi
该单位的双字母国家/地区代码是什么?
  [Unknown]:  china
CN=xuZhang, OU=fingerTip, O=fingerTip, L=suqian, ST=suqianshi, C=china是否正确?
  [否]:  y
 
输入 <tomcat> 的密钥口令
        (如果和密钥库口令相同, 按回车):
再次输入新口令:
 
Warning:
JKS 密钥库使用专用格式。建议使用 "keytool -importkeystore -srckeystore ./server.keystore -destkeystore ./server.keystore -deststoretype pkcs12" 迁移到行业标准格式 PKCS12。
 
Dell@zhanxuPC MINGW64 /d/keystore
$

 

 

 

 

 2.新建springboot项目,将上一步生成的keystone文件复制到项目的根目录,在application.properties添加如下配置

server.port=443
server.ssl.key-store=server.keystore
server.ssl.key-alias=tomcat
server.ssl.enabled=true
server.ssl.key-store-password=你刚刚设置密码
server.ssl.key-store-type=JKS

3.http访问自动转https访问

向spring容器中注入两个Bean,代码如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
@Bean
public Connector connector(){
    Connector connector=new Connector("org.apache.coyote.http11.Http11NioProtocol");
    connector.setScheme("http");
    connector.setPort(80);
    connector.setSecure(false);
    connector.setRedirectPort(443);
    return connector;
}
 
@Bean
public TomcatServletWebServerFactory tomcatServletWebServerFactory(Connector connector){
    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(connector);
    return tomcat;
}

 

作者:Bury丶冬天
链接:https://www.jianshu.com/p/8d4aba3b972d
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
posted @   码哥之旅  阅读(716)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示