Springboot设置Https

1、修改配置文件application.yml,并将*.jks放到resource目录下。

bash 复制代码
server:
  port: 8080
  ssl:
    key-store: classpath:*.jks
    key-store-password: *
    key-store-type: JKS
    enabled: true
    key-alias: boe.com.cn

2、添加http转https的配置

java 复制代码
@Configuration
public class TomcatConfig {
    @Bean
    public TomcatServletWebServerFactory servletContainer() {
        TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory() {
            @Override
            protected void postProcessContext(Context context) {
                SecurityConstraint constraint = new SecurityConstraint();
                constraint.setUserConstraint("CONFIDENTIAL");
                SecurityCollection collection = new SecurityCollection();
                collection.addPattern("/*");
                constraint.addCollection(collection);
                context.addConstraint(constraint);
            }
        };
        tomcat.addAdditionalTomcatConnectors(httpConnector());
        return tomcat;
    }

    @Bean
    public Connector httpConnector() {
        Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
        connector.setScheme("http");
        //Connector监听的http的端口号
        connector.setPort(8082);
        connector.setSecure(false);
        //监听到http的端口号后转向到的https的端口号
        connector.setRedirectPort(8080);
        return connector;
    }
}

3、修改pom.xml文件

一般到上一步,本地运行没有什么问题,但是打包会有问题。

xml 复制代码
<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-resources-plugin</artifactId>
    <version>3.1.0</version>
    <configuration>
        <nonFilteredFileExtensions>
            <!-- 过滤后缀为jks的证书文件 -->
            <nonFilteredFileExtension>jks</nonFilteredFileExtension>
        </nonFilteredFileExtensions>
    </configuration>
</plugin>

此时打包应该没有问题,但是部署时可能会出现端口问题,如果出现就添加一下代码

xml 复制代码
<resource>
  <directory>src/main/resources</directory>
  <filtering>true</filtering>
  <excludes>
      <!-- 替换成自己的证书文件 -->
      <exclude>*.jks</exclude>
  </excludes>
</resource>
<resource>
  <directory>src/main/resources</directory>
  <filtering>false</filtering>
  <includes>
      <!-- 替换成自己的证书文件 -->
      <include>*.jks</include>
  </includes>
</resource>

另外,如果还有问题,就很可能是端口问题,8090这个端口配置一直不成功,换成8080就好了。

相关推荐
Mahir081 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
IT_陈寒5 小时前
Redis缓存击穿把我整不会了,原来还有这手操作
前端·人工智能·后端
kyriewen6 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试
文心快码BaiduComate6 小时前
干货|Comate Harness Engineering工程实践指南
前端·后端·程序员
光辉GuangHui6 小时前
Agent Skill 也需要测试:如何搭建 Skill 评估框架
前端·后端·llm
我是谁的程序员6 小时前
Mac 上生成 AppStoreInfo.plist 文件,App Store 上架
后端·ios
irving同学462386 小时前
Node 后端实战:JWT 认证与生产级错误处理
前端·后端
Master_Azur6 小时前
单元测试——Junit单元测试框架
后端
用户8356290780516 小时前
使用 Python 进行 Word 邮件合并
后端
用户8356290780517 小时前
Python 操作 PowerPoint OLE 对象
后端·python