时间:2021-05-19
1.生成自己的注解(为了确定在哪些位置使用)
/** * 关闭patch delete的model处理,否则会报错 */@Target({ElementType.METHOD})@Retention(RetentionPolicy.RUNTIME)@Documentedpublic @interface AliasProcessor {}/** * 处理Get 请求参数的驼峰问题 * @author lw */@Target(ElementType.FIELD)@Retention(RetentionPolicy.RUNTIME)public @interface ValueFrom { /** * 参数名(别名)列表 */ String[] value();}2.实现自己的ServletModelAttributeMethodProcessor
/** * 为了减少使用 @RequestPath 将get参数封装到实体类中 重写ModelAttributeMethodProcessor * 注:由于get请求为非raw请求,spring默认使用@ModelArrtribute注解,不会自动将下划线的数据转为驼峰数据 * 所以需要自定义一个处理器,进行该操作 * * @author lw */public class AliasModelAttributeMethodProcessor extends ServletModelAttributeMethodProcessor { private ApplicationContext applicationContext; /** * 过滤掉patch请求,防止报错 */ @Override public boolean supportsParameter(MethodParameter parameter) { return parameter.getMethodAnnotation(AliasProcessor.class)!=null; } public AliasModelAttributeMethodProcessor(ApplicationContext applicationContext) { super(true); this.applicationContext=applicationContext; } @Override protected void bindRequestParameters(WebDataBinder binder, NativeWebRequest request) { AliasDataBinder aliasBinder = new AliasDataBinder(binder.getTarget(), binder.getObjectName()); RequestMappingHandlerAdapter requestMappingHandlerAdapter = this.applicationContext.getBean(RequestMappingHandlerAdapter.class); requestMappingHandlerAdapter.getWebBindingInitializer().initBinder(aliasBinder); aliasBinder.bind(request.getNativeRequest(ServletRequest.class)); }}3.自己的数据处理类
/** * 重新数据处理类 * @author lw */public class AliasDataBinder extends ExtendedServletRequestDataBinder { public AliasDataBinder(Object target, String objectName) { super(target, objectName); } /** * 复写addBindValues方法 * @param mpvs 这里面存的就是请求参数的key-value对 * @param request 请求本身, 这里没有用到 */ @Override protected void addBindValues(MutablePropertyValues mpvs, ServletRequest request) { super.addBindValues(mpvs, request); // 处理要绑定参数的对象 Class<?> targetClass = getTarget().getClass(); // 获取对象的所有字段(拿到Test类的字段) Field[] fields = targetClass.getDeclaredFields(); // 处理所有字段 for (Field field : fields) { // 原始字段上的注解 ValueFrom valueFromAnnotation = field.getAnnotation(ValueFrom.class); // 若参数中包含原始字段或者字段没有别名注解, 则跳过该字段 if (mpvs.contains(field.getName()) || valueFromAnnotation == null) { continue; } // 参数中没有原始字段且字段上有别名注解, 则依次取别名列表中的别名, 在参数中最先找到的别名的值赋值给原始字段 for (String alias : valueFromAnnotation.value()) { // 若参数中包含该别名, 则把别名的值赋值给原始字段 if (mpvs.contains(alias)) { // 给原始字段赋值 mpvs.add(field.getName(), mpvs.getPropertyValue(alias).getValue()); // 跳出循环防止取其它别名 break; } } } }}4.注册到spring中
/** * 为了获得context需要实现ApplicationContextAware接口 * @author lw */@Configurationpublic class WebmvcConfig implements ApplicationContextAware { @Autowired private RequestMappingHandlerAdapter adapter; private ApplicationContext applicationContext = null; @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { this.applicationContext=applicationContext; } /** * 将自定义的processor添加到adapter中 */ @PostConstruct protected void injectSelfMethodArgumentResolver() { List<HandlerMethodArgumentResolver> argumentResolvers = new ArrayList<>(); argumentResolvers.add(new AliasModelAttributeMethodProcessor(this.applicationContext)); argumentResolvers.addAll(adapter.getArgumentResolvers()); adapter.setArgumentResolvers(argumentResolvers); }}补充知识:springboot - mybatis - 下划线与驼峰自动转换 mapUnderscoreToCamelCase
以前都是在mybatis.xml中来配置,但是spring boot不想再用xml配置文件。网上搜寻了好久,才找到设置办法:
sessionFactoryBean.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
db配置文件源码:
package com.vip.qa.vop.config;import com.alibaba.druid.pool.DruidDataSource;import org.apache.ibatis.session.SqlSessionFactory;import org.mybatis.spring.SqlSessionFactoryBean;import org.mybatis.spring.annotation.MapperScan;import org.springframework.beans.factory.annotation.Qualifier;import org.springframework.beans.factory.annotation.Value;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.context.annotation.Primary;import org.springframework.core.io.support.PathMatchingResourcePatternResolver;import org.springframework.jdbc.datasource.DataSourceTransactionManager;import javax.sql.DataSource;import java.util.Properties;/** * Created by danny.yao on 2017/10/25. */@Configuration@MapperScan(basePackages = VOPDataSourceConfig.PACKAGE, sqlSessionFactoryRef = "vopSqlSessionFactory")public class VOPDataSourceConfig { static final String PACKAGE = "com.vip.qa.vop.mapper.vop"; @Value("${vop.datasource.url}") private String dbUrl; @Value("${vop.datasource.username}") private String dbUser; @Value("${vop.datasource.password}") private String dbPassword; @Value("${vop.datasource.driver-class-name}") private String dbDriver; @Bean(name = "vopDataSource") @Qualifier @Primary public DataSource vopDataSource() { DruidDataSource dataSource = new DruidDataSource(); dataSource.setDriverClassName(dbDriver); dataSource.setUrl(dbUrl); dataSource.setUsername(dbUser); dataSource.setPassword(dbPassword); return dataSource; } @Bean(name = "vopSqlSessionFactory") @Qualifier @Primary public SqlSessionFactory vopSqlSessionFactory(@Qualifier("vopDataSource") DataSource scepDataSource) throws Exception { final SqlSessionFactoryBean sessionFactoryBean = new SqlSessionFactoryBean(); sessionFactoryBean.setDataSource(scepDataSource); PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); sessionFactoryBean.setMapperLocations(resolver.getResources("classpath:/mybatis/vop/*.xml")); sessionFactoryBean.getObject().getConfiguration().setMapUnderscoreToCamelCase(true); return sessionFactoryBean.getObject(); }// @Bean(name = "vopTransactionManager")// @Qualifier// public DataSourceTransactionManager testDataTransactionManager() {// return new DataSourceTransactionManager(vopDataSource());// }}以上这篇为spring get请求添加自定义的参数处理操作(如下划线转驼峰)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1、定义一个自定义的filter.py模块,增加一个新的过滤类importdjango_filters#这个Q可以支持表查询,单下划线获取表字段,双下划线获取关
word弄下划线的方法如下: 1、首先选中需要打下划线的区域,选中【菜单栏】中的【下划线】。点击【下划线】,可打下划线,按【回车键】可添加多个下划线。 2、
以word为例,空白下划线显示不出来是因为word“为尾部空格添加下划线”开关没有打开,导致文字末端空格下划线打不上。解决方法如下: MicrosoftOff
以word为例,空白下划线显示不出来是因为word“为尾部空格添加下划线”开关没有打开,导致文字末端空格下划线打不上。解决方法如下: MicrosoftOff
word弄下划线,其方法有: 1、首先选中需要打下划线的区域,选中【菜单栏】中的【下划线】。点击【下划线】,可打下划线,按【回车键】可添加多个下划线。 2、