1、生成客户端证书、密钥文件
该流程请参考该博主
基于springboot实现的https单向认证和双向认证(java生成证书)_白帽菌的博客-CSDN博客_springboot单向认证
2、springboot实现
项目结构

代码实现
MyInterceptor.java
- package com.test.verfiy.config;
-
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import org.springframework.web.method.HandlerMethod;
- import org.springframework.web.servlet.HandlerInterceptor;
- import org.springframework.web.servlet.ModelAndView;
-
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import java.lang.reflect.Method;
- import java.security.cert.X509Certificate;
-
- /**
- * @author Liwei
- * @date 2022/8/3 17:34
- * @description
- */
- public class MyInterceptor implements HandlerInterceptor {
- private static final Logger logger = LoggerFactory.getLogger(MyInterceptor.class);
- @Override
- public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
- HandlerMethod handlerMethod = (HandlerMethod) handler;
- Method method = handlerMethod.getMethod();
- String methodName = method.getName();
- logger.info("====拦截到了方法:{},在该方法执行之前执行====", methodName);
- // 返回true才会继续执行,返回false则取消当前请求
- X509Certificate[] x509Certificates = (X509Certificate[]) request.getAttribute("javax.servlet.request.X509Certificate");
- X509Certificate cer = (X509Certificate)x509Certificates[0];
- logger.info("版本号:" + cer.getVersion());
- logger.info("序列号:" + cer.getSerialNumber().toString());
- logger.info("颁发者:" + cer.getSubjectDN()); // logger.info("颁发者唯一标识符: " + cer.getSubjectUniqueID().toString());
- logger.info("使用者:" + cer.getIssuerDN());
- // logger.info("使用者唯一标识符: " + cer.getIssuerUniqueID().toString());
- logger.info("有效期:from:" + cer.getNotBefore() + " to: " + cer.getNotAfter());
- logger.info("签发算法" + cer.getSigAlgName());
- logger.info("签发算法ID:" + cer.getSigAlgOID());
- logger.info("证书签名:" + cer.getSignature().toString());
- return true;
- }
- @Override
- public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
- logger.info("执行完方法之后进执行(Controller方法调用之后),但是此时还没进行视图渲染");
- }
- @Override
- public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
- logger.info("整个请求都处理完咯,DispatcherServlet也渲染了对应的视图咯,此时我可以做一些清理的工作了");
- }
- }
MyInterceptorConfig.java
- package com.test.verfiy.config;
-
- import org.springframework.context.annotation.Configuration;
- import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
- import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;
-
- /**
- * @author Liwei
- * @date 2022/8/3 17:35
- * @description
- */
- @Configuration
- public class MyInterceptorConfig extends WebMvcConfigurationSupport {
- @Override
- protected void addInterceptors(InterceptorRegistry registry) {
- registry.addInterceptor(new MyInterceptor()).addPathPatterns("/**");
- super.addInterceptors(registry);
- }
- }
VerfiyController.java
- package com.test.verfiy.controller;
-
- import org.springframework.web.bind.annotation.GetMapping;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RestController;
- /**
- * @author Liwei
- * @date 2022/7/29 16:19
- * @description
- */
- @RestController
- @RequestMapping("/api")
- public class VerfiyController {
- @GetMapping("/test")
- public String test() {
- return "Hello World!";
- }
- }
配置
server.port=443
server.ssl.enabled=true
server.ssl.key-store-type=JKS
server.ssl.key-store=classpath:localhost.jks
server.ssl.key-store-password=changeit
server.ssl.key-alias=localhost
#server.ssl.protocol=TLS
server.ssl.trust-store=classpath:localhost.jks
server.ssl.trust-store-password=changeit
server.ssl.trust-store-provider=SUN
server.ssl.trust-store-type=JKS
server.ssl.client-auth=need