错误信息:
java.lang.NullPointerException: null
at org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder.encode(BCryptPasswordEncoder.java:80) ~[spring-security-crypto-5.1.5.RELEASE.jar:5.1.5.RELEASE]
根据错误提示:
at com.hy.crowd.handler.MemberHandler.memberRegister(MemberHandler.java:74) ~[classes/:na]
MemberHandler.java:74,即:
String encode = passwordEncoder.encode(userPswd);
大致定位到下面的代码
@RequestMapping("/auth/do/member/register")
public String memberRegister(MemberVO memberVO, ModelMap modelMap){
......
// 执行密码加密
BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder();
String userPswd = memberVO.getUserPswd();
String encode = passwordEncoder.encode(userPswd);
memberVO.setUserPswd(encode);
// 创建空的 MemberPO 对象
MemberPO memberPO = new MemberPO();
// 复制属性
BeanUtils.copyProperties(memberVO, memberPO);
......
}
- 一开始以为是 BCryptPasswordEncoder 类找不到,到后来检查依赖、相关 jar 包均没错,然后逐步分析原因
打入断点进行调试
userPswd接收失败,我们看看前端的代码
- 前端与后端的参数不一致,所以导致密码加密时抛空指针异常
我们将前端参数改回 userPswd 试试,继续 debug 调试
这回可以看到userPswd获取到了,退出调试,直接运行试试
-
但这又引发了另一个错误,说是找不到userpswd,没有给一个默认值,嗯???userpswd?刚刚前端不是设置为userPswd吗?
-
因此可以猜想一下:可能是PO和VO的字段不对应,在VO转为PO时,没有转换成功
打开两个实体类看一下:
// VO
private String userPswd;
// PO
private String userpswd;
- 果然问题出在这里了,改为一致后运行成功