SpringBoot利用证书实现https双向绑定并解析客户端证书

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

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

拼命_小李

给点鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值