白话Spring(中级篇)---注解(4)

来源:互联网 发布:图片转换cad软件 编辑:程序博客网 时间:2024/05/19 02:18

[一知半解,就是给自己挖坑]

--------------------------------------------------------------------------------------------------------------------------------------------------------

清单:15:@ModelAttribute

a.前台页面提交请求并附带user相关参数,会把参数赋值给这个user对象,同时这个user对象也可以带回到前台页面,页面可以用el表达式来读取。【此方法会先从model去获取key为"user"的对象,如果获取不到会通过反射实例化一个User对象,再从request里面拿值set到这个对象,然后把这个User对象添加到model(其中key为"user").

示例代码1:

@RequestMapping(value = "/helloWorld")          public String helloWorld(@ModelAttribute("user") User user) {             user.setUserName("jizhou");             return "helloWorld";          }  

b.注解到controller层中的方法上:该Controller的所有方法在调用前,先执行此@ModelAttribute方法。

示例代码2:

@Controller@RequestMapping(value="test")public class PassportController {    @ModelAttribute    public void preRun() {        System.out.println("Test Pre-Run");    }    @RequestMapping(value="login", method=RequestMethod.POST)    public ModelAndView login(@ModelAttribute @Valid Account account, BindingResult result)        :        :    }}

特别注意:如果出现在controller层中,既有方法层面的注解,也有参数的注解。那么参数注解会覆盖方法注解的内容。

特殊场景:

@ModelAttribute("user1")  public User addUser(User user) {      return new User(520,"I love U");  } 
假设此方法是写在UserController内,那么执行UserController内带有@RequestMapping的方法之前,都会先执行此addUser方法.并且执行addUser过程中会添加两个对象到model,先添加key为"user"的对象(由addUser方法的User user引起的),再添加key为"user1"的对象(由注解@ModelAttribute("user1")引起的).

c.从form表单或者URL参数中获取对象(实际应用时即使没有注解也能获得该对象)

特别注意的是:此时,User类一定要有没有参数的构造函数。

@Controller      public class HelloWorldController {          @RequestMapping(value = "/helloWorld")          public String helloWorld(@ModelAttribute User user) {             return "helloWorld";          }      }

-------------------------------------------------------------------------------------------------------------------------------------

清单:16:@SessionAttributes

       在默认情况下,ModelMap 中的属性作用域是 request 级别是,也就是说,当本次请求结束后,ModelMap 中的属性将销毁。如果希望在多个请求中共享 ModelMap 中的属性,必须将其属性转存到 session 中,这样ModelMap 的属性才可以被跨请求访问。

      Spring 允许我们有选择地指定 ModelMap 中的哪些属性需要转存到 session 中,以便下一个请求属对应的ModelMap 的属性列表中还能访问到这些属性。这一功能是通过类定义处标注 @SessionAttributes 注解来实现的。

示例代码:

@Controller  @RequestMapping("/bbtForum.do")  @SessionAttributes("currUser") //①将ModelMap中属性名为currUser的属性  //放到Session属性列表中,以便这个属性可以跨请求访问 public class BbtForumController {  …      @RequestMapping(params = "method=listBoardTopic")      public String listBoardTopic(@RequestParam("id")int topicId, User user,  ModelMap model) {          bbtForumService.getBoardTopics(topicId);          System.out.println("topicId:" + topicId);          System.out.println("user:" + user);          model.addAttribute("currUser",user); //②向ModelMap中添加一个属性        return "listTopic";      }  }  

 我们在 ② 处添加了一个 ModelMap 属性,其属性名为 currUser,而 ① 处通过 @SessionAttributes 注解将ModelMap 中名为 currUser 的属性放置到 Session 中,所以我们不但可以在 listBoardTopic() 请求所对应的 JSP视图页面中通过 request.getAttribute(“currUser”) 和 session.getAttribute(“currUser”) 获取 user 对象,还可以在下一个请求所对应的 JSP 视图页面中通过 session.getAttribute(“currUser”) 或 ModelMap#get(“currUser”) 访问到这个属性。

 

    这里我们仅将一个 ModelMap 的属性放入 Session 中,其实 @SessionAttributes 允许指定多个属性。你可以通过字符串数组的方式指定多个属性,如 @SessionAttributes({“attr1”,”attr2”})。此外,@SessionAttributes 还可以通过属性类型指定要 session 化的 ModelMap 属性,如 @SessionAttributes(types = User.class),当然也可以指定多个类,如 @SessionAttributes(types
= {User.class,Dept.class}),还可以联合使用属性名和属性类型指定:@SessionAttributes(types = {User.class,Dept.class},value={“attr1”,”attr2”})。

特别用法:

  我们可以在需要访问 Session 属性的 controller 上加上 @SessionAttributes,然后在 action 需要的 User 参数上加上 @ModelAttribute,并保证两者的属性名称一致。SpringMVC 就会自动将 @SessionAttributes 定义的属性注入到 ModelMap 对象,在 setup action 的参数列表时,去
ModelMap 中取到这样的对象,再添加到参数列表。只要我们不去调用 SessionStatus 的 setComplete() 方法,这个对象就会一直保留在 Session 中,从而实现 Session 信息的共享。

最后,特别注意的是:@SessionAttributes 只能声明在类上,而不能声明在方法上

@Controller  @SessionAttributes("currentUser")public class GreetingController{  @RequestMapping  public void hello(@ModelAttribute("currentUser") User user){    //user.sayHello()     }  }
-------------------------------------------------------------------------------------------------------------------------------------

清单:17:@Required

@ required 负责检查一个bean在初始化时其声明的 set方法是否被执行, 当某个被标注了 @Required 的 Setter 方法没有被调用,则 Spring 在解析的时候会抛出异常,以提醒开发者对相应属性进行设置。 @Required 注解只能标注在 Setter 方法之上。因为依赖注入的本质是检查 Setter 方法是否被调用了,而不是真的去检查属性是否赋值了以及赋了什么样的值。【不会测试属性是否非空】如果将该注解标注在非 setXxxx() 类型的方法则被忽略。

示例代码:

@Required      public void setProduct(Product product) {          this.product = product;      }  
如果没有设置属性的话,抛出BeanInitializationException异常。

另外,在高于spring2.5的版本中,请配置如下内容:

<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:util="http://www.springframework.org/schema/util"   xmlns:context="http://www.springframework.org/schema/context"   xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd   http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.2.xsd   http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd">   <context:annotation-config />   ..</beans>
-------------------------------------------------------------------------------------------------------------------------------------

原文出处:

http://www.xuebuyuan.com/2174879.html

http://blog.csdn.net/xiejx618/article/details/43638537

http://blog.csdn.net/li_xiao_ming/article/details/8349115

http://blog.csdn.net/gxy3509394/article/details/8710761



0 0
原创粉丝点击