Spring中註解大全和應用


點擊上方藍字關注我們

帶你征服編程和泡妞兩座大山


  1. @Controller

  2. @RestController:

  3. @Service

  4. @Autowired

  5. @RequestMapping

  6. @RequestParam

  7. @ModelAttribute

  8. @Cacheable

  9. @CacheEvict

  10. @Resource

  11. @PostConstruct

  12. @PreDestroy

  13. @Repository

  14. @Component  

  15. @Scope

  16. @SessionAttributes

  17. @Required

  18. @Qualifier

@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的同學都知道,他有非常多的作用,因此詳細的用法
我會在下一篇文章專門講述,請關注公衆號哦,以免錯過。

@RequestParam

用於將請求參數區數據映射到功能處理方法的參數上
例如

1public Resp test(@RequestParam Integer id){
2        return Resp.success(customerInfoService.fetch(id));
3    }

這個id就是要接收從接口傳遞過來的參數id的值的,如果接口傳遞過來的參數名和你接收的不一致,也可以如下

1public Resp test(@RequestParam(value="course_id") Integer id){
2        return Resp.success(customerInfoService.fetch(id));
3    }

其中course_id就是接口傳遞的參數,id就是映射course_id的參數名

@ModelAttribute

使用地方有三種:

1. 標記在方法上。

標記在方法上,會在每一個@RequestMapping標註的方法前執行,如果有返回值,則自動將該返回值加入到ModelMap中。

A.在有返回的方法上:

當ModelAttribute設置了value,方法返回的值會以這個value爲key,以參數接受到的值作爲value,存入到Model中,如下面的方法執行之後,最終相當於 model.addAttribute("user_name", name);假如 @ModelAttribute沒有自定義value,則相當於
model.addAttribute("name", name);

1@ModelAttribute(value="user_name")
2    public String before2(@RequestParam(required = false) String name, Model model) {
3        System.out.println("進入了2:" + name);
4        return name;
5    }
B.在沒返回的方法上:

需要手動model.add方法

1    @ModelAttribute
2    public void before(@RequestParam(required = false) Integer age, Model model) {
3        model.addAttribute("age", age);
4        System.out.println("進入了1:" + age);
5    }

我們在當前類下建一個請求方法:

 1@RequestMapping(value="/mod")
2    public Resp mod(
3            @RequestParam(required = false)
 String name,
4            @RequestParam(required = false) Integer age, 
5            Model model)
{
6        System.out.println("進入mod");
7        System.out.println("參數接受的數值{name="+name+";age="+age+"}");
8        System.out.println("model傳過來的值:"+model);
9        return Resp.success("1");
10    }

在瀏覽器中輸入訪問地址並且加上參數:
http://localhost:8081/api/test/mod?name=我是小菜&age=12

最終輸出如下:

1進入了1:40
2進入了2:我是小菜
3進入mod
4參數接受的數值{name=我是小菜;age=12}
5model傳過來的值:{age=40, user_name=我是小菜}

2. 標記在方法的參數上。

標記在方法的參數上,會將客戶端傳遞過來的參數按名稱注入到指定對象中,並且會將這個對象自動加入ModelMap中,便於View層使用.
我們在上面的類中加入一個方法如下

 1@RequestMapping(value="/mod2")
2    public Resp mod2(@ModelAttribute("user_name") String user_name, 
3            @ModelAttribute("name") String name,
4            @ModelAttribute("age") Integer age,Model model)
{
5        System.out.println("進入mod2");
6        System.out.println("user_name:"+user_name);
7        System.out.println("name:"+name);
8        System.out.println("age:"+age);
9        System.out.println("model:"+model);
10        return Resp.success("1");
11    }

在瀏覽器中輸入訪問地址並且加上參數:
http://localhost:8081/api/test/mod2?name=我是小菜&age=12
最終輸出:

1進入了1:40
2進入了2:我是小菜
3進入mod2
4user_name:我是小菜
5name:我是小菜
6age:40
7model:{user_name=我是小菜, org.springframework.validation.BindingResult.user_name=org.springframework.validation.BeanPropertyBindingResult: 0 errors, name=我是小菜, org.springframework.validation.BindingResult.name=org.springframework.validation.BeanPropertyBindingResult: 0 errors, age=40, org.springframework.validation.BindingResult.age=org.springframework.validation.BeanPropertyBindingResult: 0 errors}

從結果就能看出,用在方法參數中的@ModelAttribute註解,實際上是一種接受參數並且自動放入Model對象中,便於使用。

@Cacheable

用來標記緩存查詢。可用用於方法或者類中,

當標記在一個方法上時表示該方法是支持緩存的,
當標記在一個類上時則表示該類所有的方法都是支持緩存的。

參數列表

參數解釋例子
value名稱@Cacheable(value={”c1”,”c2”}
keykey@Cacheable(value=”c1”,key=”#id”)
condition條件@Cacheable(value=”c1”,condition=”#id=1”)

比如@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”)

參數列表

參數解釋例子
value名稱@CachEvict(value={”c1”,”c2”}
keykey@CachEvict(value=”c1”,key=”#id”)
condition緩存的條件,可以爲空
allEntries是否清空所有緩存內容@CachEvict(value=”c1”,allEntries=true)
beforeInvocation是否在方法執行前就清空@CachEvict(value=”c1”,beforeInvocation=true)

@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方式進行裝配;如果沒有匹配,則回退爲一個原始類型進行匹配,如果匹配則自動裝配;

@PostConstruct

用來標記是在項目啓動的時候執行這個方法。用來修飾一個非靜態的void()方法
也就是spring容器啓動時就執行,多用於一些全局配置、數據字典之類的加載

被@PostConstruct修飾的方法會在服務器加載Servlet的時候運行,並且只會被服務器執行一次。PostConstruct在構造函數之後執行,init()方法之前執行。PreDestroy()方法在destroy()方法執行執行之後執

@PreDestroy

被@PreDestroy修飾的方法會在服務器卸載Servlet的時候運行,並且只會被服務器調用一次,類似於Servlet的destroy()方法。被@PreDestroy修飾的方法會在destroy()方法之後運行,在Servlet被徹底卸載之前

@Repository

用於標註數據訪問組件,即DAO組件

@Component

泛指組件,當組件不好歸類的時候,我們可以使用這個註解進行標註

@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實例。

@SessionAttributes

默認情況下Spring MVC將模型中的數據存儲到request域中。當一個請求結束後,數據就失效了。如果要跨頁面使用。那麼需要使用到session。而@SessionAttributes註解就可以使得模型中的數據存儲一份到session域中

參數:

  1. names:這是一個字符串數組。裏面應寫需要存儲到session中數據的名稱。

  2. types:根據指定參數的類型,將模型中對應類型的參數存儲到session中

  3. 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 將會被裝配來消除混亂。




1Redis模糊查詢在生產環境出現嚴重性能問題


2Linux性能的重要指標:打開文件數的限制


3以Vue爲例,解釋JavaScript的反應性


4Java必知必會之----Enum枚舉類揭祕


518位×××號藏什麼玄機?用js教你校驗





覺得本文對你有幫助?請分享給更多人

關注「編程×××」,提升裝逼技能




發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章