目录
- JAVA注解
- SpringMVC注解
- RestEasy注解
- JSON注解
java注解
SpringMVC注解
restEasy注解
Json注解:
@JsonInclude(JsonInclude.Include.NON_NULL) // 忽略null值
@JsonIgnoreProperties(ignoreUnknown = true) // 忽略不匹配的值
@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss") //日期格式化
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",locale = "zh", timezone = "GMT+8") //如果有时区差请用这种
Spring注解:
spring参考网址:
API地址:http://docs.spring.io/spring/docs/current/javadoc-api/
使用说明地址: http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/
官网:http://projects.spring.io/spring-framework/
@RequestMapping
访问请求路径,可以对象,方法都加上,如下面的例子,访问路径就为 uri = /rest/mytest/a/myPage,
也可以设置接收类型POST|GET
@RequestMapping(value="/suggestInfoSubmit",method=RequestMethod.POST)
@Controller
@RequestMapping("/rest/mytest/a")
public Class A{
@RequestMapping("/myPage")
public String getMyPage(){
}
}
requestMapping还支持多个地址
@RequestMapping(value= {"/index","/login","/"})
将method简化就为:GetMapping/ PostMapping
@ResponseBody
如果在方法上设置有,则返回内容,而非指向的jsp页面,否则就是查找对应的jsp页面显示。
@RequestMapping(value="/suggestInfoSubmit",method=RequestMethod.POST)
@ResponseBody
public Map<String, Object> submitSuggestInfo(@ModelAttribute GroupSuggestVO suggestVO,HttpServletRequest request){
不写返回String指向jsp页面
@RequestMapping(value = "/suggestPage")
public String getSuggestPage(Model model,HttpServletRequest request,HttpServletResponse response) throws ClientProtocolException, IOException {
logger.debug(">>>getSettingSuggestPage(Model model,HttpServletRequest request,HttpServletResponse response)");
logger.debug("<<<getSettingSuggestPage(Model model,HttpServletRequest request,HttpServletResponse response)");
return PAGE_SETTING_SUGGEST;
参数:
@PathVariable
获取路径参数,restful接口使用uri访问方式,即url的路径名称是参数的一部分。多用于GET请求。比如根据personID查找人员信息就可使用uri中加入员工ID的形式。
@RequestMapping(value="/suggestInfoSubmit/{id}",method=RequestMethod.GET)
@ResponseBody
public Map<String, Object> submitSuggestInfo(@PathVariable String
id,HttpServletRequest request){
@RequestParam
获取request中的参数
$.ajax({
url:url,
data:{name:name}
}) public Map<String, Object> submitSuggestInfo(@RequestParam("name") String userName,HttpServletRequest request){
@RequestBody
获取request中的所有参数,这种方式适合于复杂数据提交,数组,POJO对象中包含对象,或list对象。
这种方式需要将request的ajax提交 contentType:'application/json',同时将data数据 JSON.stringify。ajax默认为:( "application/x-www-form-urlencoded")
jsp:
$.ajax({
url : '****',
contentType: 'application/json',
data: JSON.stringify(person)
}) java:
@RequestMapping('')
public Map<String,Object> submitInfo(@RequestBody Person person){ }
注意:如果提交的数据是List对象类型,后台如果直接List<User> userList,接到的实质是List<LinkedHashMap>而非user对象,需要使用 User[] user来接收对象。
@ModelAttribute
@ModelAttribute可以添加在一个方法上,也可以标注在参数上。
方法上作用,大多用于整个类的所有方法的初始化操作,在进入指定的uri对应的方法前,首先执行这个类中的@ModelAttribute修饰的方法,然后再转入到实际请求方法中。
@ModelAttribute
public void init(){
system.out.println('**1***');
} @RequestMapping("***")
public String getTest(){
system.out.println('**2***');
}
注意:@ModelAttribute标注在方法上,如果有return值,则自动会装入到Model中。名字则为指定的名字。
@ModelAttribute(value="user")
public User getUser(@RequestParam String id){
User users = new User("123", "张三");
return users;
} EL表达式接收: ${requestScope.user.name} 相当于:
@ModelAttribute
public void getUser(@RequestParam String id, Model model){
User users = new User("123", "张三");
model.addAttribute("user", users);
}
如果@ModelAttribute和@RequestMapping作用于一个方法,则返回的是Model对象而非视图地址。因此要注意。
@RequestMapping(".....")
@ModelAttribute(value="user")
public String getUser(@RequestParam String id){
User users = new User("123", "张三");
return "user_page";
} ----------------
结果:
不会跳转到jsp页面。
EL表达式接收 ${user} ---结果: user_page
@ModelAttribute添加在参数上可以接收另外一个方法中添加到Model中的内容。
因Model中的方法只有addAttribute()方法,没有get方法,因此对于forward的形式,可以将前一个方法中加工获取的内容放入到model中,在需要的方法中@ModelAttribute来获取。
@ModelAttribute(value="user")
public User getUser(@RequestParam String id){
User users = new User("123", "张三");
return users;
} @RequestMapping(....)
public void getUser(@ModelAttribute('user') User user, Model model){
User users = new User("123", "张三");
}