一、ModelAndView
设置ModelAndView对象 , 根据view的名称 , 和视图解析器跳到指定的页面 .
页面 : {视图解析器前缀} + viewName +{视图解析器后缀}
<!-- 视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"
id="internalResourceViewResolver">
<!-- 前缀 -->
<property name="prefix" value="/WEB-INF/jsp/" />
<!-- 后缀 -->
<property name="suffix" value=".jsp" />
</bean>
对应的controller类
public class ControllerTest1 implements Controller {
public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
//返回一个模型视图对象
ModelAndView mv = new ModelAndView();
mv.addObject("msg","ControllerTest1");
mv.setViewName("test");
return mv;
}
}
二、ServletAPI
通过设置ServletAPI , 不需要视图解析器
(request/response)
- 通过HttpServletResponse进行输出
- 通过HttpServletResponse实现重定向
- 通过HttpServletResponse实现转发
@Controller
public class ResultGo {
@RequestMapping("/result/t1")
public void test1(HttpServletRequest req, HttpServletResponse rsp) throws IOException {
rsp.getWriter().println("Hello,Spring BY servlet API");
}
@RequestMapping("/result/t2")
public void test2(HttpServletRequest req, HttpServletResponse rsp) throws IOException {
rsp.sendRedirect("/index.jsp");
}
@RequestMapping("/result/t3")
public void test3(HttpServletRequest req, HttpServletResponse rsp) throws Exception {
//转发
req.setAttribute("msg","/result/t3");
req.getRequestDispatcher("/WEB-INF/jsp/test.jsp").forward(req,rsp);
}
}
三、SpringMVC
视图解析器的作用就是简化路径,没有视图解析器的时候就需要写路径的全称
- 无视图解析器
@Controller
public class ResultSpringMVC {
@RequestMapping("/rsm/t1")
public String test1(){
//转发 无视图解析器
return "/index.jsp";
}
@RequestMapping("/rsm/t2")
public String test2(){
//转发二
return "forward:/index.jsp";
}
@RequestMapping("/rsm/t3")
public String test3(){
//重定向
return "redirect:/index.jsp";
}
}
- 有视图解析器
@Controller
public class ResultSpringMVC2 {
@RequestMapping("/rsm2/t1")
public String test1(){
//转发
return "test";
}
@RequestMapping("/rsm2/t2")
public String test2(){
//重定向
return "redirect:/index.jsp";
//return "redirect:hello.do"; //hello.do为另一个请求/
}
@RequestMapping("/hello")
public String hello(String name){
System.out.println(name);
return "hello";
}
}
重定向 , 不需要视图解析器 , 本质就是重新请求一个新地方嘛 , 所以注意路径问题
总结:forword和redirect都不会走视图解析器,只有两个都不写才会走视图解析器
四、数据处理
1.处理提交数据
- 提交的域名称和处理方法的参数名一致
url: http://localhost:8080/hello?name=cai
处理方法
@RequestMapping("/hello")
public String hello(String name){
System.out.println(name);
return "hello";
}
- 提交的域名称和处理方法的参数名不一致
url: http://localhost:8080/hello?username=cai
处理方法
@RequestMapping("/hello")
public String hello(@RequestParam("username")String name){
System.out.println(name);
return "hello";
}
- 提交的是一个对象
实体类
public class User {
private int id;
private String name;
private int age;
//构造
//get/set
//tostring()
}
url:据 : http://localhost:8080/mvc04/user?name=cai&id=1&age=15
@RequestMapping("/user")
public String user(User user){
System.out.println(user);
return "hello";
}
2.数据显示到前端
- ModelAndView
通过此方法显示数据需要注册bean
<bean class="com.cai.controller.ControllerTest1" id="/controllerTest1" />
public class ControllerTest1 implements Controller {
@Override
public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
//ModelAndView 模型和视图
ModelAndView mv = new ModelAndView();
//封装对象,放在ModelAndView中。Model
String aa = "HelloSpringMVC!";
mv.addObject("msg",aa);
//封装要跳转的视图,放在ModelAndView中
mv.setViewName("controllerTest"); //: /WEB-INF/jsp/controllerTest.jsp
return mv;
}
}
- ModelMap
通过http://localhost:8080/ControllerTest2/hello?username=cai访问
@RequestMapping("/ControllerTest2/hello")
public String hello(@RequestParam("username") String name, ModelMap model){
//封装要显示到视图中的数据
//相当于req.setAttribute("name",name);
model.addAttribute("name",name);
System.out.println(name);
return "hello";
}
- Model
通过http://localhost:8080/ControllerTest2/hello1?username=cai访问
@RequestMapping("/ControllerTest2/hello1")
public String hello(@RequestParam("username") String name, Model model){
//封装要显示到视图中的数据
//相当于req.setAttribute("name",name);
model.addAttribute("msg",name);
System.out.println(name);
return "hello";
}
Model 只有寥寥几个方法只适合用于储存数据,简化了新手对于Model对象的操作和理解;
ModelMap 继承了 LinkedMap ,除了实现了自身的一些方法,同样的继承 LinkedMap 的方法和特性;
ModelAndView 可以在储存数据的同时,可以进行设置返回的逻辑视图,进行控制展示层的跳转。