閱讀本文約需要6分鐘
大家好,我是你們的導師,我每天都會在這裡給大家分享一些幹貨内容(當然了,周末也要允許老師休息一下哈)。上次老師跟大家分享了團隊開發中Git最佳實踐的知識,今天跟大家分享下Spring中的18個注解的知識。
1 @Controller
辨別一個該類是Spring MVC controller處理器,用來建立處理http請求的對象.
2 @RestController
Spring4之後加入的注解,原來在@Controller中傳回json需要@ResponseBody來配合,如果直接用@RestController替代@Controller就不需要再配置@ResponseBody,預設傳回json格式。
3 @Service
用于标注業務層元件,說白了就是加入你有一個用注解的方式把這個類注入到spring配置中
4 @Autowired
用來裝配bean,都可以寫在字段上,或者方法上。
預設情況下必須要求依賴對象必須存在,如果要允許null值,可以設定它的required屬性為false,例如:
@Autowired(required=false)
5 @RequestMapping
類定義處: 提供初步的請求映射資訊,相對于 WEB 應用的根目錄。
方法處: 提供進一步的細分映射資訊,相對于類定義處的 URL。
6 @RequestParam
用于将請求參數區資料映射到功能處理方法的參數上
例如
這個id就是要接收從接口傳遞過來的參數id的值的,如果接口傳遞過來的參數名和你接收的不一緻,也可以如下
其中course_id就是接口傳遞的參數,id就是映射course_id的參數名
7 @ModelAttribute
使用地方有三種:
7.1 标記在方法上
标記在方法上,會在每一個@RequestMapping标注的方法前執行,如果有傳回值,則自動将該傳回值加入到ModelMap中。
(1) 在有傳回的方法上:當ModelAttribute設定了value,方法傳回的值會以這個value為key,以參數接受到的值作為value,存入到Model中,如下面的方法執行之後,最終相當于
model.addAttribute("user_name", name);假如 @ModelAttribute沒有自定義value,則相當于
model.addAttribute("name", name);
(2) 在沒傳回的方法上:
需要手動model.add方法
我們在目前類下建一個請求方法:
在浏覽器中輸入通路位址并且加上參數:
http://localhost:8081/api/test/mod?name=我是小菜&age=12
最終輸出如下:
7.2 标記在方法的參數上
标記在方法的參數上,會将用戶端傳遞過來的參數按名稱注入到指定對象中,并且會将這個對象自動加入ModelMap中,便于View層使用.我們在上面的類中加入一個方法如下
在浏覽器中輸入通路位址并且加上參數:
http://localhost:8081/api/test/mod2?name=我是小菜&age=12
最終輸出:
從結果就能看出,用在方法參數中的@ModelAttribute注解,實際上是一種接受參數并且自動放入Model對象中,便于使用。
8 @Cacheable
用來标記緩存查詢。可用用于方法或者類中,當标記在一個方法上時表示該方法是支援緩存的,當标記在一個類上時則表示該類所有的方法都是支援緩存的。
參數清單
比如@Cacheable(value="UserCache") 辨別的是當調用了标記了這個注解的方法時,邏輯預設加上從緩存中擷取結果的邏輯,如果緩存中沒有資料,則執行使用者編寫查詢邏輯,查詢成功之後,同時将結果放入緩存中。
但凡說到緩存,都是key-value的形式的,是以key就是方法中的參數(id),value就是查詢的結果,而命名空間UserCache是在spring*.xml中定義。
9 @CacheEvict
@CacheEvict用來标記要清空緩存的方法,當這個方法被調用後,即會清空緩存。
@CacheEvict(value=”UserCache”)
參數清單
10 @Resource
@Resource的作用相當于@Autowired
隻不過@Autowired按byType自動注入,
而@Resource預設按 byName自動注入罷了。
@Resource有兩個屬性是比較重要的,分是name和type,Spring将@Resource注解的name屬性解析為bean的名字,而type屬性則解析為bean的類型。是以如果使用name屬性,則使用byName的自動注入政策,而使用type屬性時則使用byType自動注入政策。如果既不指定name也不指定type屬性,這時将通過反射機制使用byName自動注入政策。
@Resource裝配順序:
1、如果同時指定了name和type,則從Spring上下文中找到唯一比對的bean進行裝配,找不到則抛出異常
2、如果指定了name,則從上下文中查找名稱(id)比對的bean進行裝配,找不到則抛出異常
3、如果指定了type,則從上下文中找到類型比對的唯一bean進行裝配,找不到或者找到多個,都會抛出異常
4、如果既沒有指定name,又沒有指定type,則自動按照byName方式進行裝配;如果沒有比對,則回退為一個原始類型進行比對,如果比對則自動裝配;
11 @PostConstruct
@PostConstruct用來标記是在項目啟動的時候執行這個方法。用來修飾一個非靜态的void()方法
也就是spring容器啟動時就執行,多用于一些全局配置、資料字典之類的加載
被@PostConstruct修飾的方法會在伺服器加載Servlet的時候運作,并且隻會被伺服器執行一次。PostConstruct在構造函數之後執行,init()方法之前執行。PreDestroy()方法在destroy()方法執行執行之後執
12 @PreDestory
被@PreDestroy修飾的方法會在伺服器解除安裝Servlet的時候運作,并且隻會被伺服器調用一次,類似于Servlet的destroy()方法。被@PreDestroy修飾的方法會在destroy()方法之後運作,在Servlet被徹底解除安裝之前
13 @Repository
@Repository用于标注資料通路元件,即DAO元件
14 @Component
@Component泛指元件,當元件不好歸類的時候,我們可以使用這個注解進行标注
15 @Scope
@Scope用來配置 spring bean 的作用域,它辨別 bean 的作用域。
預設值是單例
1、singleton:單例模式,全局有且僅有一個執行個體
2、prototype:原型模式,每次擷取Bean的時候會有一個新的執行個體
3、request:request表示該針對每一次HTTP請求都會産生一個新的bean,同時該bean僅在目前HTTP request内有效
4、session:session作用域表示該針對每一次HTTP請求都會産生一個新的bean,同時該bean僅在目前HTTP session内有效
5、global session:隻在portal應用中有用,給每一個 global http session 建立一個Bean執行個體。
16 @SessionAttributes
預設情況下Spring MVC将模型中的資料存儲到request域中。當一個請求結束後,資料就失效了。如果要跨頁面使用。那麼需要使用到session。而@SessionAttributes注解就可以使得模型中的資料存儲一份到session域中
參數:
1、names:這是一個字元串數組。裡面應寫需要存儲到session中資料的名稱。
2、types:根據指定參數的類型,将模型中對應類型的參數存儲到session中
3、value:和names是一樣的。
17 @Required
适用于bean屬性setter方法,并表示受影響的bean屬性必須在XML配置檔案在配置時進行填充。否則,容器會抛出一個BeanInitializationException異常。
18 @Qualifier
@Qualifier當你建立多個具有相同類型的 bean 時,并且想要用一個屬性隻為它們其中的一個進行裝配,在這種情況下,你可以使用 @Qualifier 注釋和 @Autowired 注釋通過指定哪一個真正的 bean 将會被裝配來消除混亂。
今天就分享這麼多,關于Spring中的18個注解,你學會了多少?歡迎在留言區評論,對于有價值的留言,我們都會一一回複的。如果覺得文章對你有一丢丢幫助,請點右下角【在看】,讓更多人看到該文章。
【我們直招】我月薪2萬招人了!