功能分析
用户访问请求
输入:原始密码、两遍新密码
服务器判断旧密码是否正确以及两遍新密码是否一致,如果都正确就修改密码,否则给前端返回错误信息
开发步骤
三层架构
1.数据层
修改用户密码
2.业务层
验证原始密码是否正确、验证两次输入的新密码是否正确、修改用户密码
3.视图层
修改完密码后重定向到登陆界面
如果有错误就给页面返回错误信息
开发中。。。
1.数据层之前就写好了
2.业务层
要返回错误信息,所以返回类型为Map封装错误信息
//修改用户密码
public Map<String, Object> updatePassword(int userId,String oldPassword,String newPassword,String newPassword2){
Map<String, Object> map = new HashMap<>();
//空值处理
if(StringUtils.isBlank(oldPassword)){
map.put("oldPasswordMsg","旧密码不能为空");
return map;
}else if(StringUtils.isBlank(newPassword) || StringUtils.isBlank(newPassword2)){
map.put("newPasswordMsg","新密码不能为空");
return map;
}
//验证原始密码是否正确
User user = userMapper.selectById(userId);
oldPassword = CommunityUtil.md5(oldPassword+user.getSalt());
if(! user.getPassword().equals(oldPassword)){
map.put("errorOldPassword","旧密码错误!");
return map;
}
//验证两次输入的新密码是否一致
if(!newPassword.equals(newPassword2)){
map.put("errorTwoPassword","两次输入的新密码不一致!");
return map;
}
//修改密码
newPassword = CommunityUtil.md5(newPassword+user.getSalt());
userMapper.updatePassword(userId,newPassword);
return map;
}
3.视图层
//修改密码
@RequestMapping(path = "/updatePassword",method = RequestMethod.POST)
public String updatePassword(String oldPassword,
String newPassword,String newPassword2,Model model){
User user = hostHolder.getUser();
Map<String, Object> map = userService.updatePassword(user.getId(), oldPassword, newPassword, newPassword2);
if (map == null || map.isEmpty()) {
model.addAttribute("msg", "修改密码成功!请重新登陆");
return "redirect:/login";
} else {
model.addAttribute("oldPasswordMsg", map.get("oldPasswordMsg"));
model.addAttribute("newPasswordMsg", map.get("newPasswordMsg"));
model.addAttribute("errorOldPassword", map.get("errorOldPassword"));
model.addAttribute("errorTwoPassword", map.get("errorTwoPassword"));
return "/site/setting";
}
}