【HandlerMethodArgumentResolver】关于拦截请求参数并设置回去的解析器

文章介绍了如何在SpringMVC中创建并注册自定义的HandlerMethodArgumentResolver,以便转换和处理请求参数。解析器类需要实现接口并支持特定参数类型,如本例中的String类型。在配置类中注册解析器后,它将在Controller方法接收请求参数时生效,允许对参数进行拦截和修改。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

HandlerMethodArgumentResolver是Spring MVC提供的一种机制,用于将请求参数转换为Controller方法的参数。您可以使用自定义的HandlerMethodArgumentResolver来处理请求参数,并在需要时修改它们。

下面是一些实现步骤:

创建一个实现了HandlerMethodArgumentResolver接口的解析器类,并在supportsParameter方法中判断是否支持要处理的参数类型,如果支持则返回true。

public class MyArgumentResolver implements HandlerMethodArgumentResolver {

    @Override
    public boolean supportsParameter(MethodParameter parameter) {
        return parameter.getParameterType().equals(String.class); // 只处理String类型的参数
    }

    @Override
    public Object resolveArgument(MethodParameter parameter, ModelAndViewContainer mavContainer,
                                  NativeWebRequest webRequest, WebDataBinderFactory binderFactory) throws Exception {
        // 获取请求参数并修改值
        String value = webRequest.getParameter(parameter.getParameterName());
        value = "modified-" + value;
        return value;
    }

}

2、在配置类中注册HandlerMethodArgumentResolver。

@Configuration
public class WebConfig implements WebMvcConfigurer {

    @Override
    public void addArgumentResolvers(List<HandlerMethodArgumentResolver> resolvers) {
        resolvers.add(new MyArgumentResolver());
    }
    
}


3、这里我们将自定义的HandlerMethodArgumentResolver添加到了默认的解析器列表中。
启动应用程序并测试解析器是否生效。
现在,当您的Controller方法接收到请求时,HandlerMethodArgumentResolver将会拦截请求参数并修改它们的值。在此示例中,我们仅处理了String类型的参数,您可以根据需要修改支持的参数类型。

### Java 全局拦截器判断请求参数Spring Boot 中,可以通过 `HandlerMethodArgumentResolver` 或者直接在自定义拦截器中的 `preHandle` 方法里解析处理 HTTP 请求参数。下面展示一种通过拦截器来获取和验证请求参数的方式。 对于全局拦截器而言,在 `preHandle` 函数内部可以访问到当前的请求对象 (`HttpServletRequest`) 和响应对象 (`HttpServletResponse`) 以及处理器 (通常是控制器方法)[^1]。为了读取 URL 参数或者表单数据,可以从 `request.getParameter()` 获取特定名称的查询字符串参数;而对于 JSON 类型的数据,则可能需要先将输入流转换成字符串再做进一步解析: ```java import org.springframework.web.method.HandlerMethod; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; // 自定义拦截器类部分代码片段 @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { if (!(handler instanceof HandlerMethod)) { return true; // 如果不是映射到具体的方法则放行 } String paramValue = request.getParameter("paramName"); // 获取GET/POST方式提交过来的名字叫 paramName 的参数 // 对于 POST 请求中 application/json 格式的 body 数据 StringBuilder requestBody = new StringBuilder(); BufferedReader reader = request.getReader(); String line; while ((line = reader.readLine()) != null){ requestBody.append(line); } // 这里可以根据实际需求对 paramValue 或者 requestBody 做相应的逻辑判断... } ``` 当涉及到更复杂的场景比如鉴权时,还可以像 Android 平台下的 OkHttp 那样创建专门用于处理 token 的拦截器[^3]。不过这通常是在客户端 SDK 层面的操作,而在服务端更多会采用过滤器模式配合安全框架来做类似的控制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值