前言
在实际开发过程中,如果后端需要启用https访问,通常项目启动后配置nginx代理再配置https,前端调用时高版本的chrome还会因为证书未信任导致调用失败,通过摸索整理一套开发调试下的https方案,特此分享
后端配置
生成HTTPS密钥
keytool -genkeypair -alias tomcat -keyalg RSA -keysize 2048 -ext "SAN=IP:192.168.1.14" -keypass abcd@1234 -keystore frame.jks -storepass abcd@1234 -validity 360000
SAN需要设置你自己电脑的固定ip
data:image/s3,"s3://crabby-images/a282c/a282cf149901808dc6be3da9d857a651bb89e904" alt=""
https1.png
配置SSL访问
这里以2.0.0.RELEASE版本为例
server:
ssl:
key-store: classpath:systemfile/frame.jks
key-store-password: abcd@1234
key-store-type: JKS
key-alias: tomcat
如果需要打包部署测试环境,需要添加以下配置将jks密钥排除在外
true src/main/resources **/*.jks false src/main/resources **/*.jks
创建TomcatConfig配置信任
@Configuration
public class TomcatConfig {
@Bean
public TomcatServletWebServerFactory servletContainer() {
TomcatServletWebServerFactory tomcatServletContainerFactory = 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);
}
};
tomcatServletContainerFactory.addConnectorCustomizers(new FrameTomcatConnectorCustomizer());
return tomcatServletContainerFactory;
}
}
浏览器设置
使用360浏览器访问系统后台管理地址,点击地址栏的查看证书并导出
data:image/s3,"s3://crabby-images/90778/907789a8a73cb668fad0c58e654a489fe4ccac36" alt=""
https2.png
data:image/s3,"s3://crabby-images/06497/064970872f5c35131793592931faff17056213eb" alt=""
https3.png
打开360浏览期设置,搜索证书,配置SSL证书,在受信任的根证书派发机构和受信任的发布者两个tab下导入刚才导出的证书
data:image/s3,"s3://crabby-images/aebdb/aebdbcced3febd3e7f6ac4fd8b5893a431c511df" alt=""
https4.png
data:image/s3,"s3://crabby-images/dbd12/dbd128477a8c3baa360f8647824c139a674a8d34" alt=""
https5.png
关闭浏览器重新打开,访问系统地址,地址栏锁变绿则代表配置成功
data:image/s3,"s3://crabby-images/aeafa/aeafa7bf3ef6664305a6ce2ae5da2b2cc0b10d6b" alt=""
https6.png
开发调试
postman在调试https接口时在Setting目录关闭SSL验证
data:image/s3,"s3://crabby-images/a0927/a092749aa850ecfa6135b7e6abc1c9e074584487" alt=""
https7.png
【信息由网络或者个人提供,如有涉及版权请联系COOY资源网邮箱处理】
© 版权声明
部分内容为互联网分享,若有侵权请联系站长删除。
THE END
暂无评论内容