一、Spring Web MVC注解
@RequestMapping
@RequestMapping
注解的主要用途是將Web請求與請求處理類中的方法進行映射。
Spring MVC和Spring WebFlux都通過RquestMappingHandlerMapping
和RequestMappingHndlerAdapter
兩個類來提供對@RequestMapping
注解的支持。
@RequestMapping
注解對請求處理類中的請求處理方法進行標注;
@RequestMapping
注解擁有以下的六個配置屬性:
value
: 映射的請求URL或者其別名
? 指定請求的實際地址,指定的地址可以是URI Template 模式;
method
: 兼容HTTP的方法名
? 指定請求的method類型, GET、POST、PUT、DELETE等;
params
: 根據HTTP參數的存在、缺省或值對請求進行過濾
? 指定request中必須包含某些參數值時,才讓該方法處理。
header
: 根據HTTP Header的存在、缺省或值對請求進行過濾
? 指定request中必須包含某些指定的header值,才能讓該方法處理請求。
consume
: 設定在HTTP請求正文中允許使用的媒體類型
? 指定處理請求的提交內容類型(Content-Type),例如application/json, text/html;
product
: 在HTTP響應體中允許使用的媒體類型
? 指定返回的內容類型,僅當request請求頭中的(Accept)類型中包含該指定類型才返回;
提示:在使用@RequestMapping
之前,請求處理類還需要使用@Controller
或@RestController
進行標記
示例
@RestController
public class ControllerTest {@RequestMapping(value = "/demo/home", method = RequestMethod.GET)public String home() {return "home";}// controller–限制接收post 請求以及consumes="application/json"。@RequestMapping(value = "/testMethod", method = RequestMethod.POST,consumes="application/json")public String testMethod() {System.out.println("testMethod");return "SUCCESS";}// 返回值類型是json格式// text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8// 其中最后一項 : */*;q=0.8。// 該項表明可以接收任何類型的,權重系數0.8表明如果前面幾種類型不能正常接收。則使用該項進行自動分析。// application/json 幾種主流瀏覽器都可以自動解析。@RequestMapping(value = "/testMethod", method = RequestMethod.POST,produces="application/json")@ResponseBodypublic RestMessage testMethod2(Model model) throws IOException {return new RestMessage("SUCCESS");}// 設定必須包含username 和age兩個參數,且age參數不為10 (可以有多個參數)。@RequestMapping(value = "testParams", params = { "username","age!=10" })public String testParams() {System.out.println("testParamsAndHeaders");return "SUCCESS";}// 設定請求頭中第一語言必須為US。// 必須包含username 和age兩個參數,且age參數不為10 (可以有多個參數)。@RequestMapping(value = "testParamsAndHeaders", params = { "username","age!=10" }, headers = { "Accept-Language=US,zh;q=0.8" })public String testParamsAndHeaders() {System.out.println("testParamsAndHeaders");return "SUCCESS";}
}
@RequestBody
@RequestBody
在處理請求方法的參數列表中使用,它可以將請求主體中的參數綁定到一個對象中,請求主體參數是通過HttpMessageConverter
傳遞的,
根據請求主體中的參數名與對象的屬性名進行匹配并綁定值。
此外,還可以通過@Valid
注解對請求主體中的參數進行校驗。
示例
@PostMapping("/user")
public User createUser(@Valid @RequestBody User user) {return sava(user);
}
@GetMapping
@GetMapping
注解用于處理HTTP GET請求,并將請求映射到具體的處理方法中。
具體來說,@GetMapping
是一個組合注解,它相當于是@RequestMapping(method=RequestMethod.GET)
的快捷方式。
@PostMapping
@PostMapping
注解用于處理HTTP POST請求,并將請求映射到具體的處理方法中。@PostMapping
與@GetMapping
一樣,也是一個組合注解,它相當于是@RequestMapping(method=HttpMethod.POST)
的快捷方式。
@PutMapping
@PutMapping
注解用于處理HTTP PUT請求,并將請求映射到具體的處理方法中,@PutMapping
是一個組合注解,相當于是@RequestMapping(method=HttpMethod.PUT)
的快捷方式。
@DeleteMapping
@DeleteMapping
注解用于處理HTTP DELETE請求,并將請求映射到刪除方法中。@DeleteMapping
是一個組合注解,它相當于是@RequestMapping(method=HttpMethod.DELETE)
的快捷方式。
@PatchMapping
@PatchMapping
注解用于處理HTTP PATCH請求,并將請求映射到對應的處理方法中。@PatchMapping相當于是@RequestMapping(method=HttpMethod.PATCH)的快捷方式。
@ControllerAdvice
@ControllerAdvice
是@Component
注解的一個延伸注解,Spring會自動掃描并檢測被@ControllerAdvice
所標注的類。
@ControllerAdvice
需要和@ExceptionHandler
、@InitBinder
以及@ModelAttribute
注解搭配使用,主要是用來處理控制器所拋出的異常信息。
首先,我們需要定義一個被@ControllerAdvice
所標注的類,在該類中,定義一個用于處理具體異常的方法,并使用@ExceptionHandler
注解進行標記。
此外,在有必要的時候,可以使用@InitBinder
在類中進行全局的配置,還可以使用@ModelAttribute
配置與視圖相關的參數。
使用@ControllerAdvice
注解,就可以快速的創建統一的,自定義的異常處理類。
示例
@ControllerAdvice(basePackages = {"com.xie.controller"})
public class UserControllerAdvice {@InitBinderpublic void binder(WebDataBinder binder) {SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.getDefault());// String dob= "1/55/1999";// SimpleDateFormat的setLenient(true)// 這種情況下java會把你輸入的日期進行計算,比如55個月那么就是4年以后,這時候年份就會變成03年了// SimpleDateFormat的setLenient(false)// 這種情況下java不會把你輸入的日期進行計算,比如55個月那么就是不合法的日期了,直接異常dateFormat.setLenient(false);binder.registerCustomEditor(Date.class, "user", new CustomDateEditor(dateFormat, true));}@ModelAttributepublic void modelAttribute(Model model) {model.addAttribute("messgae", "User not found exception.");}@ExceptionHandler(UserNotFoundException.class)public ModelAndView userNotFoundExceptionHandler(UserNotFoundException exception) {ModelAndView modelAndView = new ModelAndView();modelAndView.addObject("exception", exception);modelAndView.setViewName("erro");return modelAndView;}
}
@ResponseBody
@ResponseBody
會自動將控制器中方法的返回值寫入到HTTP響應中。
特別的,@ResponseBody
注解只能用在被@Controller
注解標記的類中。
如果在被@RestController
標記的類中,則方法不需要使用@ResponseBody
注解進行標注。
@RestController
相當于是@Controller
和@ResponseBody
的組合注解。
@RequestMapping(value = "/testMethod")
@ResponseBody
public RestMessage testMethod2(Model model) throws IOException {return new RestMessage("SUCCESS");
}
@ExceptionHandler
@ExceptionHander
注解用于標注處理特定類型異常類所拋出異常的方法。
當控制器中的方法拋出異常時,Spring會自動捕獲異常,并將捕獲的異常信息傳遞給被@ExceptionHandler
標注的方法。
@ExceptionHandler(UserNotFoundException.class)
public ModelAndView userNotFoundExceptionHandler(UserNotFoundException exception) {ModelAndView modelAndView = new ModelAndView();modelAndView.addObject("exception", exception);modelAndView.setViewName("erro");return modelAndView;
}
@ResponseStatus
@ResponseStatus
注解可以標注請求處理方法。使用此注解,可以指定響應所需要的HTTP STATUS。
特別地,我們可以使用HttpStauts類對該注解的value屬性進行賦值。
@ResponseStatus(HttpStatus.BAD_REQUEST)
@ExceptionHandler(UserNotFoundException.class)
public ModelAndView userNotFoundExceptionHandler(UserNotFoundException exception) {ModelAndView modelAndView = new ModelAndView();modelAndView.addObject("exception", exception);modelAndView.setViewName("erro");return modelAndView;
}
@PathVariable
@PathVariable
注解是將方法中的參數綁定到請求URI中的模板變量上。
可以通過@RequestMapping
注解來指定URI的模板變量,然后使用@PathVariable
注解將方法中的參數綁定到模板變量上。
特別地,@PathVariable
注解允許我們使用value
或name
屬性來給參數取一個別名
@GetMapping("users/{id}/roles/{roleId}")public Role getUserRole(@PathVariable(name = "id") long id, @PathVariable(name = "roleId") long roleId) {return new Role();
}
@RequestParam
@RequestParam
注解用于將方法的參數與Web請求的傳遞的參數進行綁定。
使用@RequestParam
可以輕松的訪問HTTP請求參數的值。
@GetMapping("/role")public Role getUserRole(@RequestParam(name = "id") long id, @RequestParam(name = "roleId") long roleId) {return new Role();
}
// 特別的,如果傳遞的參數為空,還可以通過defaultValue設置一個默認值。
@Controller
@Controller
是@Component
注解的一個延伸,Spring會自動掃描并配置被該注解標注的類。
此注解用于標注Spring MVC的控制器。
@RestController
@RestController
是在Spring 4.0開始引入的,這是一個特定的控制器注解。
此注解相當于@Controller
和@ResponseBody
的快捷方式。
當使用此注解時,不需要再在方法上使用@ResponseBody
注解。
@ModelAttribute
通過此注解,可以通過模型索引名稱來訪問已經存在于控制器中的model。
@CrossOrigin
@CrossOrigin
注解將為請求處理類或請求處理方法提供跨域調用支持。
如果我們將此注解標注類,那么類中的所有方法都將獲得支持跨域的能力。
使用此注解的好處是可以微調跨域行為。
@CrossOrigin
@GetMapping("/role")
public Role getUserRole(@RequestParam(name = "id") long id, @RequestParam(name = "roleId") long roleId) {return new Role();
}
@InitBinder
@InitBinder
注解用于標注初始化WebDataBinider
的方法,
該方法用于對Http請求傳遞的表單數據進行處理,如時間格式化、字符串處理等。
@InitBinder
public void binder(WebDataBinder binder) {SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.getDefault());// String dob= "1/55/1999";// SimpleDateFormat的setLenient(true)// 這種情況下java會把你輸入的日期進行計算,比如55個月那么就是4年以后,這時候年份就會變成03年了// SimpleDateFormat的setLenient(false)// 這種情況下java不會把你輸入的日期進行計算,比如55個月那么就是不合法的日期了,直接異常dateFormat.setLenient(false);binder.registerCustomEditor(Date.class, "user", new CustomDateEditor(dateFormat, true));
}
二、Spring Bean 注解
@ComponentScan
@ComponentScan
注解用于配置Spring需要掃描的被組件注解注釋的類所在的包。
可以通過配置其basePackages
屬性或者value
屬性來配置需要掃描的包路徑。value
屬性是basePackages
的別名。
@Component
@Component
注解用于標注一個普通的組件類,它沒有明確的業務范圍,只是通知Spring被此注解的類需要被納入到Spring Bean容器中并進行管理。
@Service
@Service
注解是@Component
的一個延伸(特例),它用于標注業務邏輯類。
與@Component
注解一樣,被此注解標注的類,會自動被Spring所管理。
@Repository
@Repository
注解也是@Component
注解的延伸,與@Component
注解一樣,被此注解標注的類會被Spring自動管理起來,
@Repository
注解用于標注DAO層的數據持久化類。
三、Spring Dependency Inject
@DependsOn
@DependsOn
注解可以配置Spring IoC容器在初始化一個Bean之前,先初始化其他的Bean對象。
@Bean("firstBean")
@DependsOn(value = {"secondBean", "thirdBean"})
public firstBean firstBean() {return new FirstBean();
}
@Bean
@Bean
注解主要的作用是告知Spring,被此注解所標注的類將需要納入到Bean管理工廠中。
@Bean
注解的用法很簡單,在這里,著重介紹@Bean
注解中initMethod
和destroyMethod
的用法。
@Component
public class DataBaseInitializer {public void init() {System.out.println("This is init method");}public void destroy() {System.out.println("This is destroy method");}
}// 引入bean
@Bean(initMethod = "init", destroyMethod = "destroy")
public DataBaseInitializer dataBaseInitializer() {return new DataBaseInitializer();
}
@Scope
@Scope
注解可以用來定義@Component
標注的類的作用范圍以及@Bean
所標記的類的作用范圍。
@Scope
所限定的作用范圍有:singleton、prototype、request、session、globalSession
或者其他的自定義范圍。
這里以prototype
為例子進行講解。
當一個Spring Bean被聲明為prototype
(原型模式)時,在每次需要使用到該類的時候,Spring IoC容器都會初始化一個新的改類的實例。
在定義一個Bean時,可以設置Bean的scope屬性為prototype:scope=“prototype”
,也可以使用@Scope
注解設置,如下:
@Scope(value=ConfigurableBeanFactory.SCOPE_PROPTOTYPE)
兩種配置方式:// 第一種
@Bean
@Scope(value = ConfigurableBeanFactory.SCOPE_PROTOTYPE)
public DataBaseInitializer dataBaseInitializer() {return new DataBaseInitializer();
}// ----------------------------------------// 第二種
@Component
@Scope(value= ConfigurableBeanFactory.SCOPE_PROTOTYPE)
public class DataBaseInitializer {public void init() {System.out.println("This is init method");}public void destroy() {System.out.println("This is destroy method");}
}
@Scope 單例模式
當@Scope
的作用范圍設置成Singleto
n時,被此注解所標注的類只會被Spring IoC容器初始化一次。
在默認情況下,Spring IoC容器所初始化的類實例都為Singleton
。
同樣的原理,此情形也有兩種配置方式,示例代碼如@Scope
上述
@Autowired
@Autowired
注解用于標記Spring將要解析和注入的依賴項。
此注解可以作用在構造函數、字段和setter方法上。
@Primary
當系統中需要配置多個具有相同類型的Bean時,@Primary
可以定義這些Bean的優先級。
比如多個實現類ServiceImpl
,有一個實現類注解加@Primary
則優先實現該類。
@PostConstruct與@PreDestroy
值得注意的是,這兩個注解不屬于Spring,它們是源于JSR-250中的兩個注解,位于common-annotations.jar中。
@PostConstruct
注解用于標注在Bean被Spring初始化之前需要執行的方法。
@PreDestroy
注解用于標注Bean被銷毀前需要執行的方法。下面是具體的示例代碼:
@Component
public class DemoComponet {private List<String> list = new ArrayList<>();@PostConstructpublic void init() {list.add("q");list.add("w");}@PreDestroypublic void destroy() {list.clear();}
}
@Qualifier
當系統中存在同一類型的多個Bean時,@Autowired
在進行依賴注入的時候就不知道該選擇哪一個實現類進行注入。
此時,我們可以使用@Qualifier
注解來微調,幫助@Autowired
選擇正確的依賴項。
@Qualifier("要使用的實現類")
// 個人理解 java多態特征
@SpringBootApplication
@SpringBootApplication
注解是一個快捷的配置注解(啟動類注解),
在被它標注的類中,可以定義一個或多個Bean,并自動觸發自動配置Bean和自動掃描組件。
此注解相當于@Configuration
、@EnableAutoConfiguration
和@ComponentScan
的組合。
在Spring Boot應用程序的主類中,就使用了此注解。示例代碼如下:
@SpringBootApplication
public class Application{public static void main(String \[\] args){SpringApplication.run(Application.class,args);}
}
@EnableAutoConfiguration
@EnableAutoConfiguration
注解用于通知Spring,
根據當前類路徑下引入的依賴包,自動配置與這些依賴包相關的配置項。
@ConditionalOnClass與@ConditionalOnMissingClass
這兩個注解屬于類條件注解,它們根據是否存在某個類作為判斷依據來決定是否要執行某些配置。
下面是一個簡單的示例代碼:
@Configuration
@ConditionalOnClass(DataSource.class)
class MySQLAutoConfiguration {//...
}
@ConditionalOnBean與@ConditionalOnMissingBean
這兩個注解屬于對象條件注解,根據是否存在某個對象作為依據來決定是否要執行某些配置方法。
@Bean
@ConditionalOnBean(name="dataSource")
LocalContainerEntityManagerFactoryBean entityManagerFactory(){//...
}
@Bean
@ConditionalOnMissingBean
public MyBean myBean(){//...
}
@ConditionalOnProperty
@ConditionalOnProperty
注解會根據Spring配置文件中的配置項是否滿足配置要求,從而決定是否要執行被其標注的方法。示例代碼如下:
@Bean
@ConditionalOnProperty(name="alipay",havingValue="on")
Alipay alipay(){return new Alipay();
}
@ConditionalOnResource
此注解用于檢測當某個配置文件存在使,則觸發被其標注的方法,下面是使用此注解的代碼示例:
@ConditionalOnResource(resources = "classpath:website.properties")
Properties addWebsiteProperties(){//...
}
@ConditionalOnWebApplication與@ConditionalOnNotWebApplication
這兩個注解用于判斷當前的應用程序是否是Web應用程序。如果當前應用是Web應用程序,則使用 Spring WebApplicationContext
,并定義其會話的生命周期。下面是一個簡單的示例:
@ConditionalOnWebApplication
HealthCheckController healthCheckController(){//...
}
@ConditionalExpression
此注解可以讓我們控制更細粒度的基于表達式的配置條件限制。當表達式滿足某個條件或者表達式為真的時候,將會執行被此注解標注的方法。
@Bean
@ConditionalException("${localstore} && ${local == 'true'}")
LocalFileStore store(){//...
}
@Conditional
@Conditional
注解可以控制更為復雜的配置條件。在Spring內置的條件控制注解不滿足應用需求的時候,可以使用此注解定義自定義的控制條件,以達到自定義的要求。下面是使用該注解的簡單示例:
@Conditioanl(CustomConditioanl.class)
CustomProperties addCustomProperties(){//...
}
歡迎一起來學習和指導,謝謝關注!