SpringBoot相关注解
-
@SpringBootApplication
- SpringBoot的核心注解,目的是开启自动配置,例如扫描Controller等四个版型标签,WebMvc项目配置DispatcherServlet
- 一般SpringBoot项目中只有一个启动配置类,也就是贴了@SpringBootApplication注解的类
- 该注解上又贴了下面三个注解
- @SpringBootConfiguration:该注解上又贴了
@Configuration
注解,也就是说主类也间接贴了@Configuration
注解,最终表示主类是个配置类,里面能配置@Bean
对象 - @ComponentScan:表示会扫描主配置类所在包路径下的所有包及其子包里的版型标签,即解决了配置版型标签注解解析器这一步骤
- @EnableAutoConfiguration注解:该注解上贴了
@Import(AutoConfigurationImportSelector.class)
注解,表示导入了自动配置选择器这个类,这个类有个方法,getCandidateConfigurations()
,该方法主要是去读取jar包中的META-INF/spring.factories
文件,并加载该文件里配置的自动配置对象,比如FreeMarker、DataSource、DispatcherServlet、WebMvc等等;加载后,需要让这些对象起作用,那么得满足相应的条件才行;比如,需要用到WebMvc,则需要满足@ConditionalOnClass({ Servlet.class, DispatcherServlet.class, WebMvcConfigurer.class })
这些条件,当满足这些条件后,WebMvc对象就起作用了,SpringBoot就会帮我们构建出使用SpringMVC需要的先行条件,比如在Tomcat中配置DispatcherServlet
- @SpringBootConfiguration:该注解上又贴了
-
@ComponentScan:Spring配置扫描注解,扫描basePackages属性指定包路径下的所有包及其子包内的贴有版型标签的类
- 版型标签: Controller、Service、Repository、Component
- 如果没有指定包路径,则默认扫描该配置类所在的包路径
- 等价于
<context:component-scan base-package="icu.resip._03_scan" />
-
@Configuration
- Spring配置类注解,贴了这个注解,表示这个类是配置类,等价于applicationContext.xml文件
-
@Bean:Spring实例注解,贴有该注解的方法是实例方法
- 实例方法返回的对象会交给Spring容器管理起来
- bean标签中name属性等价于@Bean注解中name/value属性
- bean标签中id属性等价于实例方法的方法名
- bean标签中init-method属性等价于@Bean注解中initMethod属性
- bean标签中destroy-method属性等价于@Bean注解中destroyMethod属性
- bean标签中scope属性等价于实例方法中的@Scope注解
- 例如,
@Bean(value = "someBean", initMethod = "init", destroyMethod = "destroy")
- 功能等价于
<bean id="someBeans" scope="singleton" init-method="init" destroy-method="destroy" class="icu.resip.SomeBean" />
-
@ImportResource:Spring配置文件导入注解,导入applicationContext.xml类型的配置文件,贴在配置类上
- 如果一个配置类要使用到xml配置中的Bean,可以使用该注解
- 传入另一个xml配置文件的class路径即可,例如,
@ImportResource("classpath:applicationContext.xml")
-
@Import:Spring配置类导入注解,导入另一个配置类,贴在配置类上
- 如果一个配置类要使用另一个配置类中的Bean,可以使用该注解
- 传入另一个配置类的字节码对象即可,例如,
@Import(OtherConfig.class)
-
@Autowired:Spring属性注入注解
- 从Spring容器中拿到Bean,并注入到属性或字段中,贴在属性或set方法上
- 先根据属性类型去查找,再根据属性名称作为id去找
- 可以使用@Qualifier注解来按照id名称查找,配合@Autowired注解使用
-
@Resource:Spring属性注入注解
- 从Spring容器中拿到Bean,并注入到属性或字段中,贴在属性或set方法上
- 先根据属性名称作为id去查找,再根据属性类型去找
- 可以指定name属性查找,若指定,则只能按照name属性值查找
@Resource(name="")
-
@ModelAttribute:SpringMvc注解,贴在参数列表上
- 获取到前台传过来的参数,封装到对象中,然后将对象封装到Model中
- 可以通过value属性给对象取别名,如果不取别名,model中key是对象的类名,首字母大写转小写
- 等价于
model.addAttribute("别名", 对象)
-
@RequestMapping:SpringMvc注解,贴在类或方法上,用来处理请求地址映射
- 可以限定请求类型和响应类型等
- 可用于类或方法上
- 用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径
- 用于方法上,表示请求资源访问路径需要匹配到该映射路径,该方法才能被执行
@Controller @RequestMapping("/v1") public class HelloController { @RequestMapping(value = "/hello") public ModelAndView hello() { ModelAndView modelAndView = new ModelAndView(); //在Model中装入数据 modelAndView.addObject("msg", "你好,欢迎使用Spring MVC前端控制器"); //设置视图,跳转到指定jsp modelAndView.setViewName("/jsp/hello.jsp");; return modelAndView; } }
- params:指定request中必须包含某些参数值时,才让该方法处理
- headers:指定request中必须包含某些指定的header值,才能让该方法处理请求
- value:指定请求的实际地址,指定的地址可以是URI Template模式,可以指定多个
- method:指定请求的method类型, GET、POST、PUT、DELETE等
- consumes:指定处理请求的提交内容类型(Content-Type),如
application/json;text/html
-
@ResponseBody:SpringMvc注解,贴在方法上
- 方法上贴了该注解后,不会再跳转到其它页面,而是会返回给前台一个Json数据
@RequestMapping("/login") @ResponseBody public User login(User user){ return user; }
{"username":"kingyumu","password":"123456"}
- 方法上贴了该注解后,不会再跳转到其它页面,而是会返回给前台一个Json数据
-
@PathVariable:SpringMvc注解,贴在参数列表中
- 映射URL绑定的占位符
//URL中的 {xxx} 占位符可以通过 @PathVariable("xxx") 绑定到操作方法的入参中 @RequestMapping("/user/{id}") public String testPathVariable(@PathVariable("id") String id){ System.out.println("路径上的占位符的值="+id); return "success"; }
- 如果请求为
localhost:8080/user/admin
,可以输出路径上的占位符的值=admin
- 映射URL绑定的占位符
-
@RequestParam:SpringMvc注解,贴在参数列表上
- 可以对传入参数指定参数名
@RequestParam String inputStr // 下面的对传入参数指定为aa,如果前端不传aa参数名,会报错 @RequestParam(value="aa") String inputStr
- 可以通过required=false或者true来要求@RequestParam配置的前端参数是否一定要传
// required=false表示不传的话,会给参数赋值为null,required=true就是必须要有 @RequestMapping("testRequestParam") public String filesUpload ( @RequestParam(value="aa", required=true) String inputStr,HttpServletRequest request )
- 如果用@RequestParam注解的参数是int基本类型,但是required=false,这时如果不传参数值会报错,因为不传值,会赋值为null给int,这个不可以
@RequestMapping("testRequestParam") public String filesUpload( @RequestParam(value="aa", required=true) String inputStr, @RequestParam(value="inputInt", required=false) int inputInt, HttpServletRequest request) { // ......省略 return "index"; }
- 可以对传入参数指定参数名
-
@ControllerAdvice:贴在类上
- 控制器功能增强注解,在请求进入映射方法之前进行功能增强
@ControllerAdvice public class ErrorAdvice { /** * @ExceptionHandler 异常处理器,处理捕获到的异常,执行此方法,此方法的定义规则与映射方法一致 * @return 返回一个指定页面 */ @ExceptionHandler(RuntimeException.class) public String error() { return "/error/errorPage.html"; } }
- 如果需要传值到界面时需要使用ModelAndView对象返回
- 控制器功能增强注解,在请求进入映射方法之前进行功能增强
-
@ExceptionHandler:贴在方法上,配合@ControllerAdvice一起使用
/** * 告诉SpringMVC这个方法专门处理这个类发生的异常 * 1、给方法上随便写一个Exception,用来接受发生的异常 * 2、要携带异常信息不能给参数位置写Model * 3、返回ModelAndView就行了 * 4、如果有多个@ExceptionHandler都能处理这个异常,精确优先 * 5、全局异常处理与本类同时存在,本类优先 */ @ExceptionHandler(value = { Exception.class }) public ModelAndView handleException01(Exception exception) { System.out.println("本类的:handleException01..." + exception); // ModelAndView view = new ModelAndView("myerror"); view.addObject("ex", exception); // 视图解析器拼串 return view; }
-
@RestController:SpringMvc注解,贴在类上或方法上
@RestController = @Controller + @ResponseBody
- 贴在类上时,方法上不能再贴@ResponseBody注解
-
四个版型标签
- 这四个注解功能都相同,只是表示的意义不同而已
- @Controller:贴在表示层
- @Service:贴在业务类上
- @Repository:贴在数据访问层
- @Component:当被贴的类不属于任何一层时,用该注解
-
@Transactional:Spring Aop注解,用来配置事务,可以贴在类或方法上
- 常用属性readOnly:该属性用于设置当前事务是否为只读事务,设置为 true 表示只读,false 则表示可读写,默认值为 false,该属性一般用于只查询的方法上
-
@MapperScan,贴在主配置类上,配合@Configuration使用
- 扫描basePackages属性中指定包路径下的mapper接口,并为mapper接口动态创建实现类代理类
-
@ConfigurationProperties:贴在类或方法上
- 是在SpringBoot解析application配置文件后,将指定前缀为jdbc的属性名的值注入到对象的同名属性中
或@ConfigurationProperties("jdbc") @Bean public MyDataSource myDataSource() { MyDataSource myDataSource = new MyDataSource(); return myDataSource; }
@ConfigurationProperties("jdbc") public class MyDataSource { private String username; private String password; }
- 是在SpringBoot解析application配置文件后,将指定前缀为jdbc的属性名的值注入到对象的同名属性中
-
@Value:配合@PropertySource一起使用,贴在属性或方法上
- 使用${}将properties文件中值取出来,然后将值赋值给属性
- 例如,
@Value("${jdbc.driverClassName}")