日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

Spring中注解大全和应用

發布時間:2023/12/15 javascript 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spring中注解大全和应用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.


點擊上方藍字關注我們

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


  • @Controller

  • @RestController:

  • @Service

  • @Autowired

  • @RequestMapping

  • @RequestParam

  • @ModelAttribute

  • @Cacheable

  • @CacheEvict

  • @Resource

  • @PostConstruct

  • @PreDestroy

  • @Repository

  • @Component ?

  • @Scope

  • @SessionAttributes

  • @Required

  • @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裝配順序:

  • 如果同時指定了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 將會被裝配來消除混亂。




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


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


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


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


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





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

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




    轉載于:https://blog.51cto.com/jaybril/2175975

    總結

    以上是生活随笔為你收集整理的Spring中注解大全和应用的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。