本次实现数据的CRUD功能,数据依然以VO类形式进行数据接收。
一,建立Message.java类操作,负责数据的接收操作。
package com.SpringMVC.vo; public class Type { private String title; public String getTitle() { return title; } public void setTitle(String title) { this.title = title; } @Override public String toString() { return "Type [title=" + title + "]"; } }
和
package com.SpringMVC.vo; import java.io.Serializable; import java.util.Date; @SuppressWarnings("serial") public class Message implements Serializable{ private Integer mid; private String title; private Double price; private Date pubdate; private Type type; public Integer getMid() { return mid; } public void setMid(Integer mid) { this.mid = mid; } public String getTitle() { return title; } public void setTitle(String title) { this.title = title; } public Double getPrice() { return price; } public void setPrice(Double price) { this.price = price; } public Date getPubdate() { return pubdate; } public void setPubdate(Date pubdate) { this.pubdate = pubdate; } public Type getType() { return type; } public void setType(Type type) { this.type = type; } @Override public String toString() { return "Message [mid=" + mid + ", title=" + title + ", price=" + price + ", pubdate=" + pubdate + ", type=" + type + "]"; } }
2,定义Action。
范例:定义MessageAction
package com.SpringMVC.action; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import com.SpringMVC.vo.Message; @Controller //定义控制器 @RequestMapping("/pages/back/message/*") //整体访问路径 public class MessageAction { @RequestMapping("hello_demo") //为demo方法定义映射子路径 public void demo(Message msg) { System.out.println(msg); } }
下面由于第一次执行,可以直接利用地址重写方式传递所需要数据。
http://localhost:8080/SpringMVC/pages/back/message/hello_demo.action?mid=12&title=今日头条&price=8&type.title=天天新闻
后台服务器结果:
以上地址组成结构如下:
1,action的父路径:http://localhost:8080/SpringMVC/pages/back/message/
2,配置的方法路径:/hello_demo.action。
3,表示Message对象的组成:?mid=12&title=今日头条&price=8&type.title=天天新闻。
此时的代码最大特点是,控制器不需要编写类属性接收参数,所有的接收参数放到了处理的业务方法上。
同时避免了的实例化对象问题。
而整个操作过程中最为关键的问题是:传递的参数只需要传递属性名称即可。如果是引用的关系,则只需要按照“.”排列即可(如上面的type.title)。
在springMVC中还可以设置某一个业务方法的请求类型。如对之前的action进行修改:
package com.SpringMVC.action; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import com.SpringMVC.vo.Message; @Controller //定义控制器 @RequestMapping("/pages/back/message/*") //整体访问路径 public class MessageAction { @RequestMapping(value="hello_demo",method=RequestMethod.GET) //为demo方法定义映射子路径 public void demo(Message msg) { System.out.println(msg); } }
如果使用这种语法表示配置的方法只能使用get请求模式进行触发。也可以修改为post请求。
@Controller //定义控制器 @RequestMapping("/pages/back/message/*") //整体访问路径 public class MessageAction { @RequestMapping(value="hello_demo",method=RequestMethod.POST) //为demo方法定义映射子路径 public void demo(Message msg) { System.out.println(msg); } }
如果业务处理方法设置为POST请求,那么就表示只能怪由表单提交到此方法上。
如果某个业务操作方法,即支持POST,也可以支持GET,那么不要写RequestMethod。
对于返回值的处理,Spring MVC有一些要求,在正常开发中,往往会提供一共forword.jsp页面。这个页面的功能是进行操作功能完成后的信息提示。
范例:定义forword.jsp页面:
<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>My JSP ‘forword.jsp‘ starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <script type="text/javascript"> window.alert("${msg}"); window.location="<%=basePath%>${url}"; </script> </body> </html>
如果由一共控制器,跳转到forword.jsp页面,至少需要以下内容:
1,控制器需要知道forword.jsp页面的路径。
2,控制器需要传递若干个request属性(如上面的$(msg)和$(url))。
正因为如此,在springMVC中专门设计了一个类:ModelAndView,而这个类里面定义了如下操作方法:
1,构造方法:public ModelAndView()。
2,构造方法:public ModelAndView(String viewName),viewName,跳转的路径地址;
3,保存属性:public ModelAndView addObject(String attrivbuteName,Object attrivateValue) ;
范例:更好的处理跳转:
package com.SpringMVC.action; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.portlet.ModelAndView; import com.SpringMVC.vo.Message; @Controller //定义控制器 @RequestMapping("/pages/back/message/*") //整体访问路径 public class MessageAction { @RequestMapping(value="hello_demo") //为demo方法定义映射子路径 public ModelAndView demo(Message msg) { ModelAndView md=new ModelAndView("/Pages/forword.jsp"); md.addObject("msg","消息信息添加成功"); md.addObject("url","/index.jsp"); System.out.println(msg); return md; } }
这里通过ModelAndView ,跳转到forword.jsp页面,同时,给这个页面传递两个属性值,msg和url。
效果:
然后跳到了下一页
通过以上程序分析就可以总结出MVC设计的优势
1,避免了复杂的路径跳转的配置操作。
2,避免了项目中出现过多的“.”作为参数的情况。