1.@NonNull要手动写无参构造器
这是一个我今天研究了很久的问题,开始不知道原因是在这里,还在那想是不是@Data覆盖了无参构造,结果当然不是。先说下解决历程
1.问题起因
通过@RequestBody接收前端报文的时候报错,大致是说我构造方法有问题
java
(although at least one Creator exists): cannot deserialize from Object value
(no delegate- or property-based Creator)
我确实加上了注解解决了这个问题,但是咱们不是为了弄懂问题起因吗,就接着研究
java
@NoArgsConstructor
@AllArgsConstructor
2.new 一下
不是怀疑构造方法有问题吗,那就写个main方法,new 一下这个对象,中间一个注解一个注解的注释,排除到底是哪个注解影响了。
直到把@NonNull删掉,才发现无参构造方法生效了
3.@NonNull注解的对象 在其形成无参构造函数时,此注解不会默认形成无参构造器(问题就出在这儿)
以前确实踩过@Builder的坑,知道有@Builder的情况下,要手动加@NoArgsConstructor
@AllArgsConstructor注解,这次踩完坑lombok.NonNull记住了也要手动加构造器注解
2.警惕sql中的隐式转换
1.问题起因
2.解决思路
数据库中id是数字型,那传入字符串的时候就会做一个隐式转换。
根据隐式转换的规则,我所有的字符串的类型都会被转换为数字类型 ,那么我的。字符串转换为数字之后就变成了0,所以就会匹配到这个字段为0的记录。
它居然不报错,而是把非数字型的字符串,转换成了0
3.解决办法
我写了个正则限制了一下,这个字段只能传数字。
java
/**
* 校验字符串是不是整数
* @param str
* @return
*/
public static boolean isNumeric(String str){
for (int i = str.length();--i>=0;){
if (!Character.isDigit(str.charAt(i))){
return false;
}
}
return true;
}
3.java8中toMap时,value为null时报空指针
hashMap中,key可以为空,value也可以为空
但是今天踩得这个坑,value为空报错了
原因是toMap底层有一个merge方法,可以理解为同类项合并,就是我们每次写toMap时候都会写一个
java
(n1, n2) -> n1
java
Map<String, String> map = list.stream().collect(Collectors.toMap(
Node::getId,
Node::getName,
(n1, n2) -> n1
));
在它的merge方法里边,有个判断,value为空,就抛异常
java stream collect toMap nullPointException异常_hashmap merge的时候value是空 空指针怎么办?-CSDN博客
既然知道原因了,解决办法就简单了,你可以选择过滤到value为空的,但我是这样写的
java
// 不使用toMap()方法,直接在collect中构建map
Map<String, String> map = list.stream().collect(
HashMap::new,
(m,node) -> m.put(node.getId(),node.getId()),
HashMap::putAll
);
4.前端传递参数时,form-data 和 json 的区别
前端传递参数时,form-data 和 json 的区别_前端formdata传参-CSDN博客
先说结论:不管你怎么组合,都不会报错,你确实可以说get请求+json报文
一般get请求,delete请求,前端提交的时候会被拼接为url问号的格式。后端用@RequestParam接
一般Post请求,Put请求,用json报文,后端用@RequestBody接