数据处理及跳转
结果跳转方式#
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 , 不需要视图解析器。
1、通过 HttpServletResponse 进行输出
2、通过 HttpServletResponse 实现重定向
3、通过 HttpServletResponse 实现转发
@Controller
public class ControllerTest1 {
@RequestMapping("/result/t1")
public void test1(HttpServletRequest req, HttpServletResponse resp) throws IOException {
resp.getWriter().println("Hello!Spring by servlet API");
}
@RequestMapping("/result/t2")
public void test2(HttpServletRequest req,HttpServletResponse resp) throws IOException {
resp.sendRedirect("/index.jsp");
}
@RequestMapping("result/t3")
public void test3(HttpServletRequest req,HttpServletResponse resp) throws ServletException, IOException {
//转发
req.setAttribute("msg","/result/t3");
req.getRequestDispatcher("/WEB-INF/jsp/test.jsp").forward(req,resp);
}
}
SpringMVC#
通过 SpringMVC 来实现转发和重定向 - 无需视图解析器;
测试前,需要将视图解析器注释掉
//通过SpringMVC来实现转发和重定向 - 无需视图解析器
@Controller
public class ControllerTest2 {
@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";
}
}
数据处理#
处理提交数据#
1、提交的域名称和处理方法的参数名一致
提交数据 : http://localhost:8080/hello?name=hudu
处理方法 :
public class ControllerTest3 {
@RequestMapping("/hello")
public String test1(String name, Model model) {
// System.out.println(name);
model.addAttribute("msg",name);
return "test";
}
}
2、提交的域名称和处理方法的参数名不一致
提交数据 : http://localhost:8080/hello?username=hudu
处理方法 :
@RequestMapping("/hello2")
public String test2(@RequestParam("username") String name, Model model) {
model.addAttribute("msg",name);
return "test";
}
3、提交的是一个对象
要求提交的表单域和对象的属性名一致,参数使用对象即可
1、实体类
public class User {
private int id;
private String name;
private int age;
//构造
//get/set
//tostring()
}
2、提交数据 : http://localhost:8080/mvc04/user?name=hudu&id=1&age=15
3、处理方法 :
@RequestMapping("/user")
public String test3(User user){
System.out.println(user);
return "hello";
}
如果使用对象的话,前端传递的参数名和对象名必须一致,否则就是 null。
数据显示到前端#
第一种:通过 ModelAndView
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;
}
}
第二种:通过 ModelMap
ModelMap
@RequestMapping("/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
Model
@RequestMapping("/ct2/hello")
public String hello(@RequestParam("username") String name, Model model){
//封装要显示到视图中的数据
//相当于req.setAttribute("name",name);
model.addAttribute("msg",name);
System.out.println(name);
return "test";
}
对比#
简单来说:
Model 只有寥寥几个方法只适合用于储存数据,简化了对于 Model 对象的操作和理解;
ModelMap 继承了 LinkedMap ,除了实现了自身的一些方法,同样的继承 LinkedMap 的方法和特性;
ModelAndView 可以在储存数据的同时,可以进行设置返回的逻辑视图,进行控制展示层的跳转。
本作品采用《CC 协议》,转载必须注明作者和本文链接