转驼峰,自定义注解,获取bean字段

博客提到前端整体传参时参数名非驼峰写法,后台用bean接收,需自定义将参数转换成可识别的,处理成符合后台要求的格式添加到实体中完成参数解析,还涉及自定义参数转换到实体bean、自定义注解,以及在spring - mvc.xml中加入自定义解析器等内容。

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

 

2018年08月09日 15:53:48 变味的麦芽糖 阅读数 5222

 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.youkuaiyun.com/u013476435/article/details/81538099

因前端整体传参时,参数名都不是驼峰写法,类似 music_name,music_type,

因此在后台需要加上@RequestParam("music_name")String musicName  来接收,

但是后台中是用bean来接收的

 
  1. @RequestMapping(value = "/test",method = {RequestMethod.POST})

  2. @ResponseBody

  3. public void test( MusicInfo musicinfo) {

  4. System.out.println("进来了" + musicinfo.getMusicName());

  5. }

 因此需要自定义去将参数转换成可以识别的 如果前端传music_name,

我们处理成musicName并添加到MusicInfo实体中,完成参数的解析.

自定义参数转换到实体bean并实现HandlerMethodArgumentResolver

 
  1. import org.springframework.beans.BeanUtils;

  2. import org.springframework.core.MethodParameter;

  3. import org.springframework.web.bind.support.WebDataBinderFactory;

  4. import org.springframework.web.context.request.NativeWebRequest;

  5. import org.springframework.web.method.support.HandlerMethodArgumentResolver;

  6. import org.springframework.web.method.support.ModelAndViewContainer;

  7. import java.lang.reflect.Field;

  8. import java.util.Iterator;

  9.  
  10. /**

  11. * @author qi.liu

  12. * @create 2018-08-09 下午 2:21

  13. * @desc 描述:

  14. **/

  15. public class TestDiyRequestParamResolver implements HandlerMethodArgumentResolver {

  16. @Override

  17. public boolean supportsParameter(MethodParameter parameter) {

  18. return parameter.hasParameterAnnotation(DiyRequestParam.class);

  19. }

  20.  
  21. @Override

  22. public Object resolveArgument(MethodParameter parameter,

  23. ModelAndViewContainer mavContainer, NativeWebRequest webRequest,

  24. WebDataBinderFactory binderFactory) throws Exception {

  25. //生成结果的对象

  26. Object resultObject = BeanUtils.instantiate(parameter.getParameterType());

  27. //未经过处理的字段名 music_name

  28. String sourceTemp;

  29. //经过处理的字段名 musicName

  30. String executeTemp;

  31. //传参的值 例如 music_name=asdmsakdlasjd 的value

  32. String[] values;

  33. //得到bean中的方法

  34. Field[] frr = parameter.getParameterType().getDeclaredFields();

  35. for (Iterator<String> itr = webRequest.getParameterNames(); itr

  36. .hasNext(); ) {

  37. sourceTemp = itr.next();

  38. executeTemp = sourceTemp;

  39. // music_name -> musicName

  40. while (executeTemp.indexOf("_") > 0) {

  41. Integer indexOf = executeTemp.indexOf("_");

  42. executeTemp = executeTemp.replaceFirst("_", "");

  43. executeTemp = executeTemp.substring(0, indexOf) + executeTemp.substring(indexOf, indexOf + 1).toUpperCase() + executeTemp.substring(indexOf + 1, executeTemp.length());

  44. }

  45. //去赋值

  46. for (int i = 0; i < frr.length; i++) {

  47. frr[i].setAccessible(true);

  48. if (executeTemp.equals(frr[i].getName())) {

  49. values = webRequest.getParameterValues(sourceTemp);

  50. frr[i].set(resultObject, values[0]);

  51. }

  52. }

  53. }

  54. return resultObject;

  55. }

  56. }

自定义注解 DiyRequestParam

 
  1. /**

  2. * @author qi.liu

  3. * @create 2018-08-09 下午 2:22

  4. * @desc 描述:

  5. **/

  6. @Target({ElementType.PARAMETER})

  7. @Retention(RetentionPolicy.RUNTIME)

  8. @Documented

  9. public @interface DiyRequestParam {

  10. String value() default "";

  11.  
  12. boolean required() default true;

  13.  
  14. String defaultValue() default "\n\t\t\n\t\t\n\ue000\ue001\ue002\n\t\t\t\t\n";

  15. }

在spring-mvc.xml中加入自定义的 TestDiyRequestParamResolver 

 
  1. <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">

  2. <property name="customArgumentResolvers">

  3. <list>

  4. <bean class="net.okdi.o2o.beautiful.controller.TestDiyRequestParamResolver">

  5. </bean>

  6. </list>

  7. </property>

  8. </bean>

在参数前加上

 
  1.  
  2. @RequestMapping(value = "/test",method = {RequestMethod.POST})

  3. @ResponseBody

  4. public void test(@DiyRequestParam MusicInfo musicinfo) {

  5. System.out.println("进来了" + musicinfo.getMusicName());

  6. }

 

看下效果

后台接收到

 

### 使用 FastJSON 实现 JSON 字符串到驼峰命名风格 Java 对象的换 当使用 FastJSON 进行 JSON 到 Java 对象的换时,如果遇到 JSON 的键是以蛇形命名法(snake_case),而目标 Java 类中的字段采用的是驼峰命名法(camelCase),可以通过特定的方法来完成这种换。 对于简单的场景可以直接利用 `parseObject` 方法并指定类类型参数来进行换[^1]: ```java public XwRequest json2Bean(JSON json) { return JSON.toJavaObject(json, XwRequest.class); } ``` 为了确保下划线分隔的名字能够被正确映射为驼峰形式,在调用 `parseObject` 或者其他序列化方法之前设置全局配置项是一个有效手段。具体来说就是通过修改 `ParserConfig.getGlobalInstance().setNamingPolicy(NamingStrategy)` 来设定名策略[^2]。不过更常见也更为推荐的做法是在反序列化过程中让 FastJSON 自动处理这种情况,即无需额外编码即可支持从 snake_case 至 camelCase 的变。 另外一种方式则是针对个别字段应用注解[@JSONField](https://github.com/alibaba/fastjson/wiki/JSONField),这允许开发者自定义每个属性的具体行为,包括但不限于重写其访问器方法名以及控制是否开启大小写的敏感度等特性[^3]。 #### 示例代码展示如何将带有下划线的 JSON 数据化为遵循驼峰约定的对象实例: 假设有一个名为 `UserDetails` 的 POJO 类,其中包含两个私有成员变量:`user_name` 和 `email_address`;现在希望将其对应的 JSON 表达式解析为此类的一个新实体,并且使这些成员按照驼峰规则存储于内存之中(`userName`, `emailAddress`)。 ```java import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.annotation.JSONField; class UserDetails { @JSONField(name="user_name") private String userName; @JSONField(name="email_address") private String emailAddress; // Getters and Setters omitted for brevity } // 假设我们拥有如下所示的一条记录作为输入源数据 String jsonString = "{\"user_name\":\"John Doe\",\"email_address\":\"john.doe@example.com\"}"; // 执行换操作 UserDetails userDetails = JSON.parseObject(jsonString, UserDetails.class); System.out.println(userDetails.getUserName()); // 输出: John Doe System.out.println(userDetails.getEmailAddress()); // 输出: john.doe@example.com ``` 此段程序展示了即使原始 JSON 文本采用了不同的命名习惯,仍然可以借助 FastJSON 提供的功能轻松地创建出符合预期格式的目标对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值