Python 官方文档:入门教程 => 点击学习
核心点 1、实现接口 org.springframework.WEB.method.support.HandlerMethodArgumentResolver su
添加到Spring容器中
接口addArgumentResolvers方法,将自己的参数解析器加入到列表中
有点懒,也不想直接找一个例子了,之前正好写过一个,允许前端定义查询表达式,可以让前端自定义查询字段查询条件和查询值,然后进行and和or的组合,那么就每个条件就是一个查询对象,多个的话就组成一个查询对象列表对象,这里只展示思路,就补贴实际的类的代码了。
简单说明一下, 这个参数解析器是用来解析List<QueryParam>这个形式的参数类型的。
org.springframework.web.method.support.HandlerMethodArgumentResolver
public class QueryParamArgumentResolver implements HandlerMethodArgumentResolver {
@Override
public boolean supportsParameter(MethodParameter parameter) {
boolean isList = List.class.equals(parameter.getParameterType());
if (isList) {
Type genericType = parameter.getGenericParameterType();
if (genericType instanceof ParameterizedType) {
ParameterizedType parameterizedType = (ParameterizedType) genericType;
Type actualTypeArgument = parameterizedType.getActualTypeArguments()[0];
return actualTypeArgument.getTypeName().equals(QueryParam.class.getName());
}
}
return false;
}
@Override
public List<QueryParam> resolveArgument(MethodParameter parameter, ModelAndViewContainer mavContainer,
NativeWebRequest webRequest, WebDataBinderFactory binderFactory) throws Exception {
String queryParamsStr = webRequest.getParameter(ContexTKEy.queryParams.name());
if (StrUtil.isBlank(queryParamsStr)) {
return Collections.emptyList();
}
final List<QueryParam> params = JSONUtil.getInstance()
.readValue(queryParamsStr, new TypeReference<List<QueryParam>>() {
@Override
public Type getType() {
return super.getType();
}
});
if (CollectionUtil.isNotEmpty(params)) {
for (QueryParam param : params) {
if (param.getRelative() == null) {
param.setRelative(QueryParam.Relative.AND);
}
if (param.getOp() == null) {
param.setOp(QueryParam.Op.EQ);
}
}
}
return params;
}
}
这里采用直接实现org.springframework.web.servlet.config.annotation.WebMvcConfigurer接口,通过增加@Configuration注解,即充当了配置类,又可以实现添加webmvc功能的接口
@Configuration
public class CoreWebConfig implements WebMvcConfigurer {
@Bean
public QueryParamArgumentResolver queryParamArgumentResolver() {
return new QueryParamArgumentResolver();
}
@Override
public void addArgumentResolvers(List<HandlerMethodArgumentResolver> resolvers) {
resolvers.add(queryParamArgumentResolver());
}
}
相同的一个接口,即需要满足对方用Content-Type: application/json这种格式传输,那么对应的后台接口就需要用@RequestBody来注解参数;还有一些老的用户用application/x-www-fORM-urlencoded这种传参的话,那么后台参数一定不能使用@RequestBody来注释参数,因为这两种请求方式对应的后台的参数解析器是不一样的。
那么如果我们想要相同的写法,两种参数都支持的话,就需要自定义参数解析器了。
当然需要明确一点,这个自定义的参数解析器和其它可能会有点不一样,因为其实对应的两种参数解析,springMVC都有了自己对应的参数解析器,我们现在只是在前面拦截一层,根据根据Content-Type做一层转发,最后还是委托给对应的参数解析器来完成这个工作。
关于这一块,之前写过一篇文章了,可以参考自定义参数解析器同一个参数支持多种Content-Type。
好了,以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。
--结束END--
本文标题: SpringBoot项目实用功能之实现自定义参数解析器
本文链接: https://lsjlt.com/news/132869.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0