SpringBoot开启HTTPS

springboot添加https

命令行需要采用管理员权限(C盘)

keytool -genkey -alias tomcat  -storetype PKCS12 -keyalg RSA -keysize 2048  -keystore keystore.p12 -validity 3650
  1. -storetype 指定密钥仓库类型
  2. -keyalg 生证书的算法名称,RSA是一种非对称加密算法
  3. -keysize 证书大小
  4. -keystore 生成的证书文件的存储路径
  5. -validity 证书的有效期

propertites.yml配置

server:
  port: 8443
  ssl:
    key-store: src\main\resources\keystore.p12      keystore.p12为文件名,放入resources文件下
    key-store-password: 123456                      生成keystore.p12时输入的密码
    keyStoreType: PKCS12
    keyAlias: tomcat

设置http到https的重定向

@Configuration
public class HttpToHttpsConfig {
	@Value("${http.port}")
	int httpPort;
	@Value("${server.port}")
	int httpsPort;

	/**
	 * it's for set http url auto change to https
	 */
	@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.setPort(httpPort);
		connector.setSecure(false);
		connector.setRedirectPort(httpsPort);
		return connector;
	}

}

根据keystore.p12导出客户端证书(双击使用加入电脑的信任列表)

keytool -export -alias tomcat -keystore keystore.p12 -storetype PKCS12 -keypass 123456 -file client.cer
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值