spring 的幾種註解

一:@Autowired(按類型注入)
1.1經過 @Autowired的使用來消除 set ,get方法。
@Autowired
private Dao dao;
這樣就能夠刪除set ,get方法和spring中的相關配製了。
<bean id="service" class="com.Servcie">
<property name="dao" ref="dao">
</bean>
<bean id="dao" class="com.dao"/>spring

1.2經過@Autowired屬的Setter方法給父類中的屬性注入值。
@Autowired
public void setDataSource(DataSource ds){
super.setDataSource(ds);
}json

1.3當不能肯定 Spring 容器中必定擁有某個類的 Bean 時,能夠在須要自動注入該類 Bean 的地方可使用 @Autowired(required = false) ,這等於告訴 Spring:在找不到匹配 Bean 時    也不報錯。@Autowired(required = false)

二:@Resource(按名稱注入)
1.1
@Resource(name="dao")
private Dao dao;

@Repository("dao")
Public class Dao{}

三:@Controller    
1.1 EG: @Controller("com.LogAction") //標識控制器bean id

四:@RequestMapping
1.1EG: @RequestMapping("log/login.htm",
                        method="
RequestMethod.POST",
headers="Content-Type=application/json",
consumes={"application/json"},
produces={"application/json"})
參數有(value={"",""},method={"RequestMethod.GET",""},params={"submitFlag=create",""}...)
 
value:請求的url,params :請求的參數中含有該值;在@RequestMapping 中 params 的參數組合使用是 且的意思
headers:請求參數 Content-Type=application/json 表示客戶端發送的文件內容類型,從而服務器按這種類型來解析;
                Accept=application/xml 表示客戶端只接收該類型內容從而服務器發送該類型數據
headers="Content-Type=application/json" 對應--> consumes="application/json"
headers="Accept=application/json" 對應--> produces="application/json"
consumes:表示服務器只能消費的數據類型;produces:標示服務器只負責生產的數據

五:@Component = @Service or @Reponsitory
1.1 當組件描述不明確時能夠統一用@Component


六:參數綁定註解
數組

一、@RequestParam綁定單個請求參數值;
二、@PathVariable綁定URI模板變量值;
三、@CookieValue綁定Cookie數據值
四、@RequestHeader 綁定請求頭數據;
五、@ModelValue綁定參數到命令對象;
六、@SessionAttributes綁定命令對象到session;
七、@RequestBody綁定請求的內容區數據並能進行自動類型轉換等。
八、@RequestPart 綁定「multipart/data」數據,除了能綁定@RequestParam 能作到的請求參數外,還能綁定上傳的文件

 

@RequestParam (value="",required=false[默認true],defaultValue="zhang")
綁定單個參數  public void method(@RequestParam(value="username") String name){}  --> ...htm?username=zzd

        綁定多個參數  public void method(@RequestParam(value="role")  String[] roles){}  或者  
      public void method(@RequestParam(value="role" )  List<String> roles)
 {} -->...htm?role=admin&role=test服務器

 

@RequestMapping(value="/users/{userId}/topics/{topicId}") 
EG:public String test(  @PathVariable(value="userId")  int  userId,  @PathVariable(value="topicId")  int topicId)
     
將url 中的{userId}、{topicId} 綁定到@PathVariable 標註的變量中

 

@CookieValue
public String test(@CookieValue(value="JSESSIONID", defaultValue="") String sessionId) session

 

@RequestHeader
public String test(  @RequestHeader("User-Agent") String userAgent,      @RequestHeader(value="Accept") String[] accepts)

 

六:
app

三:備註

<context:component-scan/> 掃描指定的包中的類上的註解,經常使用的註解有:ui

@Controller 聲明Action組件
@Service    聲明Service組件    @Service("myMovieLister") 
@Repository 聲明Dao組件
@Component   泛指組件, 當很差歸類時. 
@RequestMapping("/menu")  請求映射
@Resource  用於注入,( j2ee提供的 ) 默認按名稱裝配,@Resource(name="beanName") 
@Autowired 用於注入,(srping提供的) 默認按類型裝配 
@Transactional( rollbackFor={Exception.class}) 事務管理
@ResponseBody
@Scope("prototype")   設定bean的做用域url

相關文章
相關標籤/搜索