关于数据传递:
客户端传递数据到服务端:
1.使用普通的形式
A.传递简单的数据
如果是说你传递的数据的名称跟控制层中的形参的名称不一致的情况下需要使用
注解: @RequestParam()如果存在在注解的话,那么一定要传递对应的名称,除非设置required="false"
个人建议是保存名称一致
B.传递的数据为表单的数据
(1)使用普通的表单进行提交,那么你需要注意的是 name="类中的数据",如果是说我的类中有关联的类型那么name="role.role_id",表单中含有name属性才是传递数据
(2)使用Jquery中的表单序列化操作,该操作比较方便,但是如果是日后工作当中,会只用客户端传递JSON的数据形式的字符串
2.使用的是占位符
A.使用占位符操作,那么你一般情况下需要传递简单的数据,形式如下/sys/100/tomcat
控制层当中,一定为如下的格式 /sys/{id}/{name},并且对应的形参中一定要含有@PathVariable注解
B.其实占位符可以传递复杂的数据,但是一般情况下需要你知道如何这是正则表达式
服务端传递数据到客户端:
1.一共介绍了5种形式
(1)使用原生的二阶段用request进行传递数据,需要你再方法(HttpServletRequest)形式
(2)ModelAndView
(3)方法名(Map<String,Object> map)注意这些形参对进行实例化操作
(4)方法名(ModelMap modelMap)注意你可以使用 Ctrl+T的快捷键进行查看继承的关系
(5)方法名(Model model)
(6)返回客户端的数据为JSON的格式
JavaScript Object Navtion 轻量级的传输数据格式
XML
2.关于在客户端显示数据的形式
A.使用EL表达式和JSTL标签
B.使用SpringMVC提供的标签
单独传递数据为日期
<h2>日期传递</h2> <form action="client01" method="get"> <input type="text" name="mydate" placeholder="输入日期格式"> <input type="submit" value="提交日期数据"> </form> |
一般情况下的,日期格式我们习惯于使用YYYY-MM-DD的形式 2012-12-12的这种形式,HTTP Status 400[数据转换失败] @DateTimeFormat(pattern="yyyy-MM-dd")这种形式的话,那么你的客户端只能传递该种形式 疑问,我想让两种形式2016.01.01格式? |
@RequestMapping("/client01") public ModelAndView test01(@RequestParam(name="mydate") @DateTimeFormat(pattern="yyyy-MM-dd")Date date){ System.out.println(date); return null; } |
单独传递数据为金钱
<h2>金钱传递</h2> <form action="client02" method="get"> <input type="text" name="money" placeholder="输入金钱格式"> <input type="submit" value="提交金钱数据"> </form> |
关于金钱,我们一般习惯于使用表示方法为: 1,123,000.00的形式,如果工作当中涉及到金钱操作的时候,一会使用的是为BigDecimal处理金钱,还有不能使用你了解的四舍五入,需要使用银行家的四舍五入方式 |
@RequestMapping("/client02") public ModelAndView test02(@NumberFormat(pattern="#,###.##")Double money){ System.out.println(money); return null; } |
疑问,我想让两种形式2016.01.01||2016-10-10||2014/12/12格式?
我们需要使用对数据的处理注解,@InitBinder?
我们介绍的实现方式,现在我们只是了解其使用方式:
当你有客户数据传递的时候,那么我会进入含有标注@InitBinder的方法中
package com.shxt.controller; import java.awt.Component; import java.awt.Graphics; import java.awt.Rectangle; import java.beans.PropertyChangeListener; import java.beans.PropertyEditor; import java.beans.PropertyEditorSupport; import java.io.UnsupportedEncodingException; import java.util.Date; import java.util.Map; import javax.servlet.http.HttpServletRequest; import org.springframework.format.annotation.DateTimeFormat; import org.springframework.format.annotation.NumberFormat; import org.springframework.stereotype.Controller; import org.springframework.web.bind.WebDataBinder; import org.springframework.web.bind.annotation.InitBinder; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.servlet.ModelAndView; import com.shxt.model.User; @Controller//如果是你没有命名,那么id=类名的首字母小写 public class ClienDataController { @RequestMapping("/client01") public ModelAndView test01(@RequestParam(name="mydate") @DateTimeFormat(pattern="yyyy-MM-dd")Date date){//有接收客户端数据,进入@InitBinder注解的方法内部 System.out.println(date); return null; } @RequestMapping("/client02") public ModelAndView test02(@NumberFormat(pattern="#,###.##")Double money){//有接收客户端数据,进入@InitBinder注解的方法内部 System.out.println(money); return null; } @RequestMapping("/client03") public ModelAndView test03(){//没有接收客户端数据,不进入@InitBinder注解的方法内部 System.out.println("test03"); return null; } @RequestMapping("/client04") public ModelAndView test04(User user){//有接收客户端数据,进入@InitBinder注解的方法内部 System.out.println("test04"); return null; } @RequestMapping("/client05") public ModelAndView test05(HttpServletRequest request){//没有接收客户端数据,不进入@InitBinder注解的方法内部 System.out.println("test05"); return null; } @RequestMapping("/client06") public ModelAndView test06(Map<String,Object> map){//没有接收客户端数据,不进入@InitBinder注解的方法内部 System.out.println("test06"); return null; } @RequestMapping("/client07") public ModelAndView test07(String shxt) throws UnsupportedEncodingException{ //如果是GET请求解决中文乱码问题,有两种方式:请自己总结一下 /*System.out.println("test07---->>"+ new String(shxt.getBytes("ISO8859-1"),"UTF-8"));*/ System.out.println("test07---->>"+shxt); return null; } @InitBinder //当客户端传递数据的时候,并且我的控制器中的方法要接收之前,会进入该标注的方法内部进行处理 public void shxt(WebDataBinder binder){ System.out.println("请注意观察该输入语句,在上面情况下输出?"); //String.class为客户端传递的数据要转换成形参所对应的那个类 binder.registerCustomEditor(String.class, new PropertyEditorSupport(){ //内部类-->>什么是Java内部类,如何使用? @Override public void setAsText(String text) throws IllegalArgumentException { System.out.println("客户端传递的数据为:"+text); setValue(text+":齐天大圣");//重新赋值 } }); } } |
配置工具类,进行对日期的解决方案
@InitBinder//当客户端传递数据的时候,并且我的控制器中的方法要接收之前,会进入该标注的方法内部进行处理 public void shxt(WebDataBinder binder){ binder.registerCustomEditor(Date.class, new PropertyEditorSupport(){ @Override public void setAsText(String text) throws IllegalArgumentException { setValue(DateUtils.parseDate(text)); } }); } |
针对于DateUtils的工具类,默认需要使用commons-lang-2.6.jar包的支持
//注意使用这种方式去实现,自己的工具类的方式? //可以回去自己去实现继承Map接口,实现一个HashMap,很好玩 public class DateUtils extends org.apache.commons.lang.time.DateUtils { private static String[] parsePatterns = { "yyyy-MM-dd", "yyyy-MM-dd HH:mm:ss", "yyyy-MM-dd HH:mm", "yyyy-MM", "yyyy/MM/dd", "yyyy/MM/dd HH:mm:ss", "yyyy/MM/dd HH:mm", "yyyy/MM", "yyyy.MM.dd", "yyyy.MM.dd HH:mm:ss", "yyyy.MM.dd HH:mm", "yyyy.MM"}; |
介绍@ModelAttribute注解方式介绍
1.模拟情景,更新操作,如下图:
这情景模式,就产生如下的模拟代码:
JSP页面代码: <h2>用户更新</h2> <form action="user/update" method="post"> <input type="hidden" name="_method" value="put"> <input type="text" name="account" value="wukong"> <input type="text" name="user_id" value="1000"> <input type="submit" value="用户更新"> </form> |
持久化类代码,省略getter和setter public class User { private Integer user_id; private String user_name; private String account; private String password; |
package com.shxt.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.WebDataBinder; import org.springframework.web.bind.annotation.InitBinder; import org.springframework.web.bind.annotation.ModelAttribute; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.servlet.ModelAndView; import com.shxt.model.User; @Controller public class UserController { @RequestMapping(value="/user/update",method=RequestMethod.PUT) public ModelAndView update(User user){ System.out.println(user); return null; } @RequestMapping("/shxt") public ModelAndView test01(){ System.out.println("哈哈哈"); return null; } @ModelAttribute public void init2(){ System.out.println("******"); } @ModelAttribute public void init1(Integer user_id){ System.out.println("======"+user_id); } @InitBinder//想想这个使用规则? public void 数据(WebDataBinder binder){ System.out.println("四海兴唐"); } } 问题:在控制台输出的结果是什么? |
那么我们已经搞定了上面的代码,下面我们来进行改造,代码如下:
package com.shxt.controller; import java.util.Map; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.ModelAttribute; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.servlet.ModelAndView; import com.shxt.model.User; @Controller public class UserController { @RequestMapping(value="/user/update",method=RequestMethod.PUT) public ModelAndView update(@ModelAttribute(value="user_data")User user){ System.out.println(user); return null; } @RequestMapping("/shxt") public ModelAndView test01(){ System.out.println("哈哈哈"); return null; } @ModelAttribute public void init2(){ System.out.println("******"); } @ModelAttribute public void init1(Integer user_id,Map<String,Object> map){ //System.out.println("======"+user_id); if(user_id!=null){ //查询数据库,模拟通过主键查询数据库操作 System.out.println("我进来了"); User user = new User(); user.setUser_id(1000); user.setAccount("wukong"); user.setPassword("123456"); user.setUser_name("悟空"); map.put("user_data",user); } } } |