注解相关

Bean常用注解 ?

定义Bean的注解  

@Controller/@Controller("Bean的名称")

定义控制层Bean,如Action

@Service/@Service("Bean的名称")

定义业务层Bean

@Repository/@Repository("Bean的名称")

定义DAO层Bean

@Component

定义Bean, 不好归类时使用
自动装配Bean的注解  

@Autowired

按名称装配Bean

@Autowired(required=true)

一定要找到匹配的Bean,否则抛异常。 默认值就是true

@Autowired@Qualifier("bean的名字")

按名称装配Bean,@Qualifier与@Autowired组合使用,解决按类型匹配找到多个Bean问题。

@Resource

按类型装配Bean
定义Bean的作用域和生命过程  

@Scope("prototype")

五种取值,常用两种:单例:singleton,多例:prototype request,session,globalSession

 

@Scope注解的其他三种

request

再次说明request,session和global session类型只实用于web程序,通常是和XmlWebApplicationContext共同使用。

<bean id ="requestPrecessor" class="...RequestPrecessor" scope="request" />

Spring容器,即XmlWebApplicationContext 会为每个HTTP请求创建一个全新的RequestPrecessor对象,当请求结束后,该对象的生命周期即告结束,如同java web中request的生命周期。当同时有100个HTTP请求进来的时候,容器会分别针对这10个请求创建10个全新的RequestPrecessor实例,且他们相互之间互不干扰,简单来讲,request可以看做prototype的一种特例,除了场景更加具体之外,语意上差不多。

session

对于web应用来说,放到session中最普遍的就是用户的登录信息,对于这种放到session中的信息,我们可以使用如下形式的制定scope为session:

<bean id ="userPreferences" class="...UserPreferences" scope="session" />

Spring容器会为每个独立的session创建属于自己的全新的UserPreferences实例,比request scope的bean会存活更长的时间,其他的方面没区别,如果java web中session的生命周期

global session

<bean id ="userPreferences" class="...UserPreferences" scope="globalsession" />

global session只有应用在基于porlet的web应用程序中才有意义,它映射到porlet的global范围的session,如果普通的servlet的web 应用中使用了这个scope,容器会把它作为普通的session的scope对待。

@Resource注解?

@Resource的作用相当于@Autowired,@Resource默认按 byName自动注入。

@Resource有两个属性是比较重要的,分是name和type,Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。

  1. 如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常   

  2. 如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常   

  3. 如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常   

  4. 如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配;

@AutoWired和@Resource的区别?

1、 @Autowired与@Resource都可以用来装配bean. 都可以写在字段(filed)上,或写在setter方法上。

2、 @Autowired默认按类型装配(这个注解是属业spring的),默认情况下必须要求依赖对象必须存在,

如果要允许null值,可以设置它的required属性为false,如:@Autowired(required=false)

@Autowired按照类型装配,如果找不到匹配的或者找到一个以上相匹配的时候,会抛异常(BeanCreationException) ,可以结合@Qualifier注解进行使用,@Qualifire注解指定了名称(此时同时指定了类型和名称)。如下:

@Autowired()@Qualifier("baseDao")
private BaseDao baseDao;

3、@Resource(这个注解属于J2EE的),默认按照名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名进行安装名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配,找不到抛异常。

@Resource(name="baseDao")
private BaseDao baseDao;

推荐使用@Resource

@Resource注解在字段上,这样就不用写setter方法了,并且这个注解是属于J2EE的,减少了与spring的耦合。这样代码看起就比较优雅。

Springmvc中@RequestMapping 属性用法归纳?

@RequestMapping

RequestMapping是一个用来处理请求地址映射的注解,可用于类或方法上。

用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。

RequestMapping注解有六个属性(分成三类进行说明)与六个基本用法,

1、 value, method;

value: 指定请求的实际地址,指定的地址可以是URI Template 模式;

method: 指定请求的method类型, GET、POST、PUT、DELETE等;

2、 consumes,produces;

consumes: 指定处理请求的提交内容类型(Content-Type),例如application/json, text/html;

produces: 指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回;

3、 params,headers;

params: 指定request中必须包含某些参数值是,才让该方法处理。

headers: 指定request中必须包含某些指定的header值,才能让该方法处理请求。

猜你喜欢

转载自www.cnblogs.com/lvhouhou/p/11983950.html