我使用ssm框架做了一个用户登录功能和类似搜索功能的数据库查询功能,搜索功能预期实现的结果是:
当输入的查询内容在数据库中有记录时,可以返回相应的界面,如果查询不到,就会返回设置好的error.jsp界面,控制器层代码如下:
@Controller
public class UserController {
@Autowired
UserService userService;
//实现登录功能
@RequestMapping(value="login.action")
public ModelAndView login(User user) {
System.out.println(user.getUsername()+" "+user.getPassword());
ModelAndView mav = new ModelAndView();
User newuser = userService.login(user);
if (newuser != null) {
// 放入转发参数
mav.addObject("newuser", newuser);
// 放入jsp路径
mav.setViewName("index");
} else
mav.setViewName("login");
return mav; }
//实现注册功能
@RequestMapping(value= "register.action")
public ModelAndView register(User user) {
ModelAndView mav = new ModelAndView();
if(user.getUsername().equals("")||user.getPassword().equals(""))
mav.setViewName("register");
else {
userService.register(user);
// 放入jsp路径
mav.setViewName("login");
}
return mav;
}
//实现搜索功能
@RequestMapping(value="searchmovie.action")
public ModelAndView searchmovie(Movie movie) {
ModelAndView mav = new ModelAndView();
Movie newmovie = userService.searchmovie(movie);
System.out.println(movie.getMname());
if (newmovie.getMname().equals("死侍")) {
mav.addObject("newmovie", newmovie);
mav.setViewName("detail1");
}
else if (newmovie.getMname().equals("左耳")) {
mav.addObject("newmovie", newmovie);
mav.setViewName("detail2");
}
else if (newmovie.getMname().equals("战狼")) {
mav.addObject("newmovie", newmovie);
mav.setViewName("detail3");
}
else if (newmovie.getMname().equals("边境风云")) {
mav.addObject("newmovie", newmovie);
mav.setViewName("detail4");
}
else if (newmovie.getMname().equals("正义联盟")) {
mav.addObject("newmovie", newmovie);
mav.setViewName("detail5");
}
else if (newmovie.getMname().equals("指环王")) {
mav.addObject("newmovie", newmovie);
mav.setViewName("detail6");
}
else if (newmovie.getMname().equals("蝙蝠侠")) {
mav.addObject("newmovie", newmovie);
mav.setViewName("detail7");
}
else if (newmovie.getMname().equals("fate")) {
mav.addObject("newmovie", newmovie);
mav.setViewName("detail8");
}
else if (newmovie.getMname().equals("神探夏洛克")) {
mav.addObject("newmovie", newmovie);
mav.setViewName("detail9");
}
else {
mav.setViewName("error"); }
return mav;
}
}
登录功能可以正常实现,如果没有相应的数据会返回登录界面,但是搜索功能如果查询不到就会出现500错误:
另外,mapper映射文件两个功能是分开写的,但是两个功能的service层是在一块写的。(userMapper是登录功能的映射,MovieMapper是搜索功能的映射)
写入数据库中已经存放的数据“死侍”,正常跳转
输入数据库中没有的内容,“死侍2”,跳转失败:
在控制器里中通过输出语句输出对象的getMname()方法,其中是有值存在的:
但是却显示空指针异常
请教大佬是什么问题?为什么跳转会失败,困扰很久了:(