SpringBoot中经常用的注解及其作用???

    技术2022-07-11  122

    @SpringBootApplication:约定优于配置   @Service:注解在类上,表示这是一个业务层bean @Controller:注解在类上,表示这是一个控制层bean @Repository:注解在类上,表示这是一个数据访问层bean @Component:注解在类上,表示通用bean ,value不写默认就是类名首字母小写 @SpringBootApplication=@ComponentScan+@Configuration+@EnableAutoConfiguration。 放在主程序入口类上, 主程序入口类(启动类) 放在root 包下,这样程序启动时所有的相关配置,类都能扫描,查找到 @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:赋值,将注解转换成对象。给对象赋值 @EnableAutoConfiguration:启用 Spring 应用程序上下文的自动配置,试图猜测和配置您可能需要的bean。自动配置类通常采用基于你的classpath 和已经定义的 beans 对象进行应用。被 @EnableAutoConfiguration 注解的类所在的包有特定的意义,并且作为默认配置使用。通常推荐将 @EnableAutoConfiguration 配置在 root 包下,这样所有的子包、类都可以被查找到。 @ComponentScan:注解在类上,扫描标注了@Controller等注解的类,注册为bean 。@ComponentScan 为   @Configuration:注解的类配置组件扫描指令。@ComponentScan 注解会自动扫描指定包下的全部标有 @Component注解的类,并注册成bean,当然包括 @Component下的子注解@Service、@Repository、 @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”)) @EnableCaching,开启缓存配置,支持子类代理或者AspectJ增强 @CacheConfig,在一个类下,提供公共缓存配置 @Cacheable,放着方法和类上,缓存方法或类下所有方法的返回值 @CachePut,每次先执行方法,再将结果放入缓存 @CacheEvict,删除缓存 @Caching,可以配置@Cacheable、@CachePut、@CacheEvict @suppresswarnings:抑制警告 @Transactional:事务注解

    Processed: 0.013, SQL: 9