ssm数据库查询后返回指定界面出现500错误

我使用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()方法,其中是有值存在的:
图片说明
但是却显示空指针异常

请教大佬是什么问题?为什么跳转会失败,困扰很久了:(

空指针了呀,newmovie.get*

空指针异常,UserController(55行)
这么明显的错误都不会看吗