实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议

2年前 (2022) 程序员胖胖胖虎阿
131 0 0

最近壹哥的一个学生在做项目时碰到了一个特殊的需求,前端浏览器需要存放跨域请求的cookie,需要将cookie的secure属性设置为true。这样一来,就要求后端的接口必须以HTTPS协议提供访问,那么我们该如何在Springboot项目中使用Https协议呢?是否一定要花钱购买数字证书才可以呢?

其实如果我们只是在开发和测试阶段,完全可以使用自定义的数字证书,并通过简单的配置,即可让Springboot程序切换成Https协议。

接下来壹哥就带各位在SpringBoot项目中实现该功能。

一. 创建自定义数字证书

首先我们得创建一个自定义的数字证书。其实在JDK中,就提供了现成的工具用于生成数字证书,我们只需打开命令行工具,执行如下代码即可生成一个数字证书。

keytool -genkeypair -alias springboot-https 
-keypass 123456 -keyalg RSA 
-keysize 2048 -validity 365 
-keystore d:/cert/springboot.keystore -storepass 123456

执行结果如下图所示:

实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议

这里会出现一个警告,我们按照提示更改一下证书密钥库的格式即可。 

keytool -importkeystore -srckeystore d:/cert/springboot.keystore 
-destkeystore d:/cert/springboot.keystore -deststoretype pkcs12

实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议

这样我们就将密钥库格式转换为pkcs12格式了,此时得到的密钥库文件如下图所示,其中springboot.keystore就是我们所需要的密钥库文件。

实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议

二. 配置Springboot

1. 导入数字证书

接着我们要将生成的密钥库文件,放入到Springboot工程中的resources目录下,如下图所示:

实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议

 2. 创建yml配置文件

然后添加如下格式的yml配置信息。

server:
  ssl:
    #开启https
    enabled: true
    #指定存放证书的密钥库文件的位置
    key-store: classpath:springboot.keystore
    #密钥库文件的格式
    key-store-type: PKCS12
    #别名,需要与创建密钥库时的别名一致
    key-alias: springboot-https
    key-password: 123456
    key-store-password: 123456

3. 创建Java测试类

这里我们可以写一个Java测试类。

@SpringBootApplication
@RestController
public class DemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }

    @RequestMapping("/")
    public String hello() {
        return "hello";
    }
}

4. 测试访问

接下来我们启动程序,并通过默认的8080端口进行访问。

实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议

此时我们会发现,当使用http协议访问时,会看到上图所示的错误提示信息,接着我们换成https协议访问。

实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议

这里由于数字证书是我们自己生成的,没有CA给我们认证,因此浏览器给出了安全提示,我们只需点击高级按钮,继续前往即可。

实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议

我们发现,最终接口就访问成功了。

实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议

三. 同时支持http协议和https协议

但在有的项目中,会要求我们同时支持http和https协议,这该怎么实现呢?我们继续往下看。

1. 配置http端口

首先我们在yml配置文件中,添加http端口号定义。

http:
  port: 8888

2. 创建配置类

接着我们在Java配置类中,向IOC容器中添加如下Bean。

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

@Bean
public ServletWebServerFactory servletContainer(){
    final Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
        connector.setPort(httpPort);
    final TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory();
    
    tomcat.addAdditionalTomcatConnectors(connector);
    return tomcat;
}

3. 启动测试

启动项目时,我们会发现如下日志,Tomcat绑定了两个端口号,其中https绑定在8080,http绑定在8888。

实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议

以Http协议访问会如下图所示,我们发现可以正常访问到接口。

实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议再以Https协议访问会如下图所示,也可以正常访问到接口。

实用干货!看壹哥如何在SpringBoot项目中同时支持https和http协议

这样我们就实现了一个项目中同时支持http和https协议,现在你是不是学会了呢?如果你还有什么别的疑问,可以在评论区留言哦。关注壹哥,每天干货都不断!

相关文章

暂无评论

暂无评论...