Spring Boot整合日期转换器(Converter)和拦截器(HandlerInterceptor)

本文介绍了如何在SpringMVC中使用DataConverter进行日期格式转换,以及如何通过WebMvcConfigurer实现拦截器功能,包括注册日期格式转换器和自定义登录拦截器,以控制请求流程并处理登录验证。

添加日期转换器(Converter)

public class DataConverter implements Converter<String, Date> {


    @Override
    public Date convert(String s) {
        try {
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
        return simpleDateFormat.parse(s);
        }catch (Exception e){
            e.printStackTrace();
            return null;
        }
    }
}

配置日期转换器(WebMvcConfigurer)

  • 说明

            WebMvcConfigurer配置类其实是Spring内部的一种配置方式,采用JavaBean的形式来代替传统的xml配置文件形式针对框架进行个性化定制,例如:拦截器,类型转化器等等。

  • 代码示例

@Component
public class SpringMVCConfig implements WebMvcConfigurer {

    //注册日期格式转换
    @Override
    public void addFormatters(FormatterRegistry registry) {
        registry.addConverter(new DataConverter());
    }
}

添加拦截器(HandlerInterceptor)

public class LoginInterceptor implements HandlerInterceptor {
    /**
     * 在控制器方法调用前执行
     * 返回值为是否中断
     * true:表示继续执行(下一个拦截器或处理器)
     * false:则会中断后续的所有操作,所以我们需要使用response来继续响应后续请求
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("==============handler执行前调用interceptor================");
        //判断用户是否登录
        User userLogin = (User) request.getSession().getAttribute("userLogin");
        if (userLogin != null) {
            return true;//执行下一个interceptor 或 handler
        }
        response.sendRedirect("/login.jsp");
        return false;//不放行
    }

    /**
     * 在控制器方法调用后,解析视图前调用,我们可以对视图和模型做进一步渲染或修改
     * 可在modelAndView中加入数据,比如当前时间
     */
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        HandlerInterceptor.super.postHandle(request, response, handler, modelAndView);
    }

    /**
     * 整个请求完成,即视图渲染结束后调用,这个时候可以做些资源清理工作,或日志记录
     */

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        HandlerInterceptor.super.afterCompletion(request, response, handler, ex);
    }
}

配置拦截器(WebMvcConfigurer)

@Component
public class SpringMVCConfig implements WebMvcConfigurer {

    //日期格式转换
    @Override
    public void addFormatters(FormatterRegistry registry) {
        registry.addConverter(new DataConverter());
    }

    //注册拦截器
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        /*
        * addPathPatterns():要拦截的内容
        * excludePathPatterns():要放行的内容
        * */
        registry.addInterceptor(new LoginInterceptor()).addPathPatterns("/**").excludePathPatterns("/user/login").excludePathPatterns("/");
    }
}

Spring Boot 应用中,拦截器(Interceptor)通常用于处理请求前后的通用逻辑,例如日志记录、身份验证或数据加密等。要实现对 API 返回数据进行 AES 加密,可以通过自定义拦截器结合 `ResponseBodyAdvice` 来完成。 ### 实现步骤 #### 1. 编写 AES 加密工具类 首先,定义一个用于 AES 加密的工具类 `AesUtil`,该类包含加密方法密钥管理逻辑。 ```java import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; import java.util.Base64; public class AesUtil { private static final String ALGORITHM = "AES/ECB/PKCS5Padding"; private static final String KEY = "1234567890abcdef"; // 16 bytes key public static String encrypt(String data) throws Exception { Cipher cipher = Cipher.getInstance(ALGORITHM); SecretKeySpec keySpec = new SecretKeySpec(KEY.getBytes(), "AES"); cipher.init(Cipher.ENCRYPT_MODE, keySpec); byte[] encryptedData = cipher.doFinal(data.getBytes()); return Base64.getEncoder().encodeToString(encryptedData); } } ``` #### 2. 实现 `ResponseBodyAdvice` 以拦截响应数据 通过实现 `ResponseBodyAdvice` 接口,可以在响应体写入之前对其进行修改,例如加密处理。 ```java import org.springframework.core.MethodParameter; import org.springframework.http.MediaType; import org.springframework.http.converter.HttpMessageConverter; import org.springframework.http.server.ServerHttpRequest; import org.springframework.http.server.ServerHttpResponse; import org.springframework.web.bind.annotation.ControllerAdvice; import org.springframework.web.servlet.mvc.method.annotation.ResponseBodyAdvice; @ControllerAdvice public class EncryptionResponseBodyAdvice implements ResponseBodyAdvice<Object> { @Override public boolean supports(MethodParameter returnType, Class<? extends HttpMessageConverter<?>> converterType) { return true; // 拦截所有返回值 } @Override public Object beforeBodyWrite(Object body, MethodParameter returnType, MediaType selectedContentType, Class<? extends HttpMessageConverter<?>> selectedConverterType, ServerHttpRequest request, ServerHttpResponse response) { try { String responseBody = body.toString(); // 可根据实际类型转换为 JSON return AesUtil.encrypt(responseBody); // 加密返回数据 } catch (Exception e) { throw new RuntimeException("加密失败", e); } } } ``` #### 3. 配置拦截器(可选) 如果需要在请求处理前进行某些操作(如日志记录或身份验证),可以配置一个拦截器。但 AES 加密更适合在响应阶段处理,因此通常不需要在拦截器中进行加密。 ```java import org.springframework.stereotype.Component; import org.springframework.web.servlet.HandlerInterceptor; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; @Component public class RequestInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 可以记录请求日志或其他预处理操作 return true; } } ``` #### 4. 注册拦截器(可选) 如果使用了拦截器,需要通过配置类将其注册到 Spring MVC 的拦截器链中。 ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; @Configuration public class WebConfig implements WebMvcConfigurer { @Autowired private RequestInterceptor requestInterceptor; @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(requestInterceptor); } } ``` ### 注意事项 - **加密性能**:对所有响应数据进行加密可能会影响性能,建议仅对敏感数据进行加密。 - **密钥管理**:密钥应妥善管理,避免硬编码在代码中,可以通过配置中心或环境变量注入。 - **数据格式**:加密前应确保数据格式为字符串(如 JSON),否则需先进行序列化。 - **兼容性**:前端需要具备解密能力,确保加密数据可被正确解析。 ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

涵冰...

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值