@Service:
注解在类上,表示这是一个业务层bean
@Controller:
注解在类上,表示这是一个控制层bean
@Repository:
注解在类上,表示这是一个数据访问层bean
@Component:
注解在类上,表示通用bean ,value不写默认就是类名首字母小写
@Autowired:
按类型注入.默认属性required= true;当不能确定 Spring 容器中一定拥有某个类的Bean 时, 可以在需要自动注入该类 Bean 的地方可以使用@Autowired(required = false), 这等于告诉Spring:在找不到匹配Bean时也不抛出BeanCreationException 异常。
@Configuration:
注解在类上,表示这是一个IOC容器,相当于spring的配置文件,java配置的方式。 IOC容器的配置类一般与 @Bean 注解配合使用,用@Configuration 注解类等价与 XML 中配置 beans,用@Bean 注解方法等价于 XML 中配置 bean。@Bean: 注解在方法上,声明当前方法返回一个Bean
@Scope:注解在类上,描述spring容器如何创建Bean实例。
1、singleton: 表示在spring容器中的单例,通过spring容器获得该bean时总是返回唯一的实例
2、prototype:表示每次获得bean都会生成一个新的对象
3、request:表示在一次http请求内有效(只适用于web应用)
4、session:表示在一个用户会话内有效(只适用于web应用)
5、globalSession:表示在全局会话内有效(只适用于web应用)
在多数情况,我们只会使用singleton和prototype两种scope,如果未指定scope属性,默认为singleton
@Value:
注解在变量上,从配置文件中读取
@ConfigurationProperties:
赋值,将注解转换成对象。给对象赋值
@SpringBootApplication:
约定优于配置 @SpringBootApplication=@ComponentScan+@Configuration+@EnableAutoConfiguration。 放在主程序入口类上, 主程序入口类(启动类) 放在root 包下,这样程序启动时所有的相关配置,类都能扫描,查找到
@EnableAutoConfiguration:
启用 Spring 应用程序上下文的自动配置,试图猜测和配置您可能需要的bean。自动配置类通常采用基于你的classpath 和已经定义的 beans 对象进行应用。被 @EnableAutoConfiguration 注解的类所在的包有特定的意义,并且作为默认配置使用。通常推荐将 @EnableAutoConfiguration 配置在 root 包下,这样所有的子包、类都可以被查找到。
@ComponentScan:
注解在类上,扫描标注了@Controller等注解的类,注册为bean 。@ComponentScan 为
@Configuration:
注解的类配置组件扫描指令。@ComponentScan 注解会自动扫描指定包下的全部标有 @Component注解的类,并注册成bean,当然包括 @Component下的子注解@Service、@Repository、@Controller。
@RestController:
@RestController 是一个结合了 @ResponseBody 和 @Controller 的注解(像:resetful接口调用时,返回的是json等就使用)
@PathVariable和@RequestParam:
都是将request里的参数的值绑定到contorl里的方法参数里的,区别在于,URL写法不同。
使用@RequestParam时,URL是这样的:http://host:port/path?参数名=参数值
使用@PathVariable时,URL是这样的:http://host:port/path/参数值
当请求参数username不存在时会有异常发生,可以通过设置属性required=false解决,例如: @RequestParam(value="username",required=false)
不写的时候也可以获取到参数值,但是必须名称对应。参数可以省略不写
@RequestMapping: 和请求报文是做对应的
1、value,指定请求的地址
2、method ,请求方法类型 这个不写的话,自适应:get或者post
3、consumes ,请求的提交内容类型
4、produces ,指定返回的内容类型 仅当request请求头中的(Accept)类型中包含该指定类型才返回
5、 params ,指定request中必须包含某些参数值
6、headers ,指定request中必须包含指定的header值
7、 name , 指定映射的名称
@RequestMapping(method = RequestMethod.GET)/@GetMapping
@Responsebody:
注解表示该方法的返回的结果直接写入 HTTP 响应正文(ResponseBody)中,一般在异步获取数据时使用,通常是在使用 @RequestMapping 后,返回值通常解析为跳转路径,加上@Responsebody 后返回结果不会被解析为跳转路径,而是直接写入HTTP 响应正文中。(@RequestMapping(value = "/change",method = RequestMethod.POST,produces = "application/json;charset=utf-8"))
@EnablCaching:
@EnableCaching注解是spring framework中的注解驱动的缓存管理功能。自spring版本3.1起加入了该注解。如果你使用了这个注解,那么你就不需要在XML文件中配置cache manager了。
@suppresswarnings:抑制警告
@Transactional:事务注解