@Controllerspring
標識一個該類是Spring MVC controller處理器,用來建立處理http請求的對象.json
1@Controller 2public class TestController { 3 @RequestMapping("/test") 4 public String test(Map<String,Object> map){ 5 6 return "hello"; 7 } 8}
@RestControllerapi
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,均可以寫在字段上,或者方法上。session
默認狀況下必需要求依賴對象必須存在,若是要容許null值,能夠設置它的required屬性爲false,例如:@Autowired(required=false)app
@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
用來標記緩存查詢。可用用於方法或者類中,
當標記在一個方法上時表示該方法是支持緩存的,當標記在一個類上時則表示該類全部的方法都是支持緩存的。
參數列表
好比@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裝配順序:
@PostConstruct
用來標記是在項目啓動的時候執行這個方法。用來修飾一個非靜態的void()方法
也就是spring容器啓動時就執行,多用於一些全局配置、數據字典之類的加載
被@PostConstruct修飾的方法會在服務器加載Servlet的時候運行,而且只會被服務器執行一次。PostConstruct在構造函數以後執行,init()方法以前執行。PreDestroy()方法在destroy()方法執行執行以後執
@PreDestroy
被@PreDestroy修飾的方法會在服務器卸載Servlet的時候運行,而且只會被服務器調用一次,相似於Servlet的destroy()方法。被@PreDestroy修飾的方法會在destroy()方法以後運行,在Servlet被完全卸載以前
@Repository
用於標註數據訪問組件,即DAO組件
@Component
泛指組件,當組件很差歸類的時候,咱們可使用這個註解進行標註
@Scope
用來配置 spring bean 的做用域,它標識 bean 的做用域。
默認值是單例
@SessionAttributes
默認狀況下Spring MVC將模型中的數據存儲到request域中。當一個請求結束後,數據就失效了。若是要跨頁面使用。那麼須要使用到session。而@SessionAttributes註解就可使得模型中的數據存儲一份到session域中
參數:
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 將會被裝配來消除混亂。
若是想學習Java工程化、高性能及分佈式、深刻淺出。微服務、Spring,MyBatis,Netty源碼分析的朋友能夠加個人Java高級交流:787707172,羣裏有阿里大牛直播講解技術,以及Java大型互聯網技術的視頻免費分享給你們。