@Controller
标識一個該類是Spring MVC controller處理器,用來創建處理http請求的對象.
1@Controller 2public class TestController { 3 @requestMapping("/test") 4 public String test(Map<String,Object> map){ 5 6 return "hello"; 7 } 8}
@RestController
Spring4之後加入的注解,原來在@Controller中返回json需要@ResponseBody來配合,如果直接用@RestController替代@Controller就不需要再配置@ResponseBody,默認返回json格式。
1@RestController 2public class TestController { 3 @RequestMapping("/test") 4 public String test(Map<String,Object> map){ 5 6 return "hello"; 7 } 8}
@Service
用于标注業務層組件,說白了就是加入你有一個用注解的方式把這個類注入到spring配置中
@Autowired
用來裝配bean,都可以寫在字段上,或者方法上。
默認情況下必須要求依賴對象必須存在,如果要允許null值,可以設置它的required屬性為false,例如:@Autowired(required=false)
@RequestMapping
類定義處: 提供初步的請求映射信息,相對于 WEB 應用的根目錄。
方法處: 提供進一步的細分映射信息,相對于類定義處的 URL。
用過RequestMapping的同學都知道,他有非常多的作用,因此詳細的用法
我會在下一篇文章專門講述,請關注公衆号哦,以免錯過。
比如@Cacheable(value="UserCache") 标識的是當調用了标記了這個注解的方法時,邏輯默認加上從緩存中獲取結果的邏輯,如果緩存中沒有數據,則執行用戶編寫查詢邏輯,查詢成功之後,同時将結果放入緩存中。
但凡說到緩存,都是key-value的形式的,因此key就是方法中的參數(id),value就是查詢的結果,而命名空間UserCache是在spring*.xml中定義.
1@Cacheable(value="UserCache")// 使用了一個緩存名叫 accountCache 2public Account getUserAge(int id) { 3 //這裡不用寫緩存的邏輯,直接按正常業務邏輯走即可, 4 //緩存通過切面自動切入 5 int age=getUser(id); 6 return age; 7}
@CacheEvict
用來标記要清空緩存的方法,當這個方法被調用後,即會清空緩存。@CacheEvict(value=”UserCache”)
參數列表
@Resource
@Resource的作用相當于@Autowired
隻不過@Autowired按byType自動注入,
而@Resource默認按 byName自動注入罷了。
@Resource有兩個屬性是比較重要的,分是name和type,Spring将@Resource注解的name屬性解析為bean的名字,而type屬性則解析為bean的類型。所以如果使用name屬性,則使用byName的自動注入策略,而使用type屬性時則使用byType自動注入策略。如果既不指定name也不指定type屬性,這時将通過反射機制使用byName自動注入策略。
@Resource裝配順序:
- 如果同時指定了name和type,則從Spring上下文中找到唯一匹配的bean進行裝配,找不到則抛出異常
- 如果指定了name,則從上下文中查找名稱(id)匹配的bean進行裝配,找不到則抛出異常
- 如果指定了type,則從上下文中找到類型匹配的唯一bean進行裝配,找不到或者找到多個,都會抛出異常
- 如果既沒有指定name,又沒有指定type,則自動按照byName方式進行裝配;如果沒有匹配,則回退為一個原始類型進行匹配,如果匹配則自動裝配;
@PostConstruct
用來标記是在項目啟動的時候執行這個方法。用來修飾一個非靜态的void()方法
也就是spring容器啟動時就執行,多用于一些全局配置、數據字典之類的加載
被@PostConstruct修飾的方法會在服務器加載Servlet的時候運行,并且隻會被服務器執行一次。PostConstruct在構造函數之後執行,init()方法之前執行。PreDestroy()方法在destroy()方法執行執行之後執
@PreDestroy
被@PreDestroy修飾的方法會在服務器卸載Servlet的時候運行,并且隻會被服務器調用一次,類似于Servlet的destroy()方法。被@PreDestroy修飾的方法會在destroy()方法之後運行,在Servlet被徹底卸載之前
@Repository
用于标注數據訪問組件,即DAO組件
@Component
泛指組件,當組件不好歸類的時候,我們可以使用這個注解進行标注
@Scope
用來配置 spring bean 的作用域,它标識 bean 的作用域。
默認值是單例
- singleton:單例模式,全局有且僅有一個實例
- prototype:原型模式,每次獲取Bean的時候會有一個新的實例
- request:request表示該針對每一次HTTP請求都會産生一個新的bean,同時該bean僅在當前HTTP request内有效
- session:session作用域表示該針對每一次HTTP請求都會産生一個新的bean,同時該bean僅在當前HTTP session内有效
- global session:隻在portal應用中有用,給每一個 global http session 新建一個Bean實例。
@SessionAttributes
默認情況下Spring MVC将模型中的數據存儲到request域中。當一個請求結束後,數據就失效了。如果要跨頁面使用。那麼需要使用到session。而@SessionAttributes注解就可以使得模型中的數據存儲一份到session域中
參數:
- names:這是一個字符串數組。裡面應寫需要存儲到session中數據的名稱。
- types:根據指定參數的類型,将模型中對應類型的參數存儲到session中
- value:和names是一樣的。
1@Controller 2@SessionAttributes(value={"names"},types={Integer.class}) 3public class ScopeService { 4 @RequestMapping("/testSession") 5 public String test(Map<String,Object> map){ 6 map.put("names", Arrays.asList("a","b","c")); 7 map.put("age", 12); 8 return "hello"; 9 } 10}
@Required
适用于bean屬性setter方法,并表示受影響的bean屬性必須在XML配置文件在配置時進行填充。否則,容器會抛出一個BeanInitializationException異常。
@Qualifier
當你創建多個具有相同類型的 bean 時,并且想要用一個屬性隻為它們其中的一個進行裝配,在這種情況下,你可以使用 @Qualifier 注釋和 @Autowired 注釋通過指定哪一個真正的 bean 将會被裝配來消除混亂。
,