Springboot单体架构http请求转换https请求来支持微信小程序调用接口
http请求转换https请求
1、话不多说,直接上代码!
application.properties配置文件
#(密钥文件路径,也可以配置绝对路径) server.ssl.key-store=classpath:证书文件名.pfx #(密钥生成时输入的密钥库口令) server.ssl.key-store-password:123456 #(密钥类型,与密钥生成命令一致) server.ssl.key-store-type:PKCS12
证书一般最好放在resources目录下
接下来配置启动类RUN.java的代码
importorg.springframework.scheduling.annotation.EnableScheduling; importorg.springframework.transaction.annotation.EnableTransactionManagement; importorg.apache.catalina.Context; importorg.apache.catalina.connector.Connector; importorg.apache.tomcat.util.descriptor.web.SecurityCollection; importorg.apache.tomcat.util.descriptor.web.SecurityConstraint; importorg.springframework.boot.SpringApplication; importorg.springframework.boot.autoconfigure.SpringBootApplication; importorg.springframework.boot.context.embedded.EmbeddedServletContainerFactory; importorg.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainerFactory; @SpringBootApplication @EnableTransactionManagement @EnableScheduling publicclassRun{ publicstaticvoidmain(String[]args)throwsException{ SpringApplication.run(Run.class,args); } /** *it'sforsethttpurlautochangetohttps */ @Bean publicEmbeddedServletContainerFactoryservletContainer(){ TomcatEmbeddedServletContainerFactorytomcat=newTomcatEmbeddedServletContainerFactory(){ @Override protectedvoidpostProcessContext(Contextcontext){ SecurityConstraintsecurityConstraint=newSecurityConstraint(); securityConstraint.setUserConstraint("CONFIDENTIAL");//confidential SecurityCollectioncollection=newSecurityCollection(); collection.addPattern("/*"); securityConstraint.addCollection(collection); context.addConstraint(securityConstraint); } }; tomcat.addAdditionalTomcatConnectors(initiateHttpConnector()); returntomcat; } /** *让我们的应用支持HTTP是个好想法,但是需要重定向到HTTPS, *但是不能同时在application.properties中同时配置两个connector, *所以要以编程的方式配置HTTPconnector,然后重定向到HTTPSconnector *@returnConnector */ privateConnectorinitiateHttpConnector(){ Connectorconnector=newConnector("org.apache.coyote.http11.Http11NioProtocol"); connector.setScheme("http"); connector.setPort(8084);//http端口(请求访问时的端口) connector.setSecure(false); connector.setRedirectPort(8444);//application.properties中配置的https端口 returnconnector; } }
以上代码直接拿走,接下来启动测试
可以访问http端口,也可访问https端口
最后附上一个小编犯的错
把代码打包到服务器了却总是不能访问,后来才发现是忘记配置服务器端口号的白名单,只需放通那个端口号就行了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。