springboot注解总结

@SpringBootApplication = (默认属性)@Configuration + @EnableAutoConfiguration + @ComponentScan。mysql

@Configuration:提到@Configuration就要提到他的搭档@Bean。使用这两个注解就能够建立一个简单的spring配置类,能够用来替代相应的xml配置文件。linux

@EnableAutoConfiguration:可以自动配置spring的上下文,试图猜想和配置你想要的bean类,一般会自动根据你的类路径和你的bean定义自动配置web

@AutoConfigureAfter:在指定的配置类初始化后再加载 
@AutoConfigureBefore:在指定的配置类初始化前加载 
@AutoConfigureOrder:数越小越先初始化

@ComponentScan:会自动扫描指定包下的所有标有@Component的类,并注册成bean,固然包括@Component下的子注解@Service,@Repository,@Controller。spring

@Entity 对实体注释。任何Hibernate映射对象都要有这个注释sql

@Table声明此对象映射到数据库的数据表,经过它能够为实体指定表(table),目录(Catalog)和schema的名字。该注释不是必须的,若是没有则系统使用默认值(实体的短类名)。数据库

@EnableScheduling开启计划任务json

1@Scheduled:声明该方法是一个计划任务,fixedRate属性设置每隔固定时间执行
2cron属性:按照指定时间执行(11时28)cron事unix和类unix(linux)系统下的定时时间

@WebServlet,在 SpringBootApplication 上使用@ServletComponentScan 注解后,Servlet、Filter、Listener 能够直接经过 @WebServlet、@WebFilter、@WebListener 注解自动注册,无需其余代码。mvc

@Transactionalapp

解决Transactional注解不回滚:
1. 检查你方法是否是public的。
2. 你的异常类型是否是unchecked异常。@Transactional(rollbackFor=Exception.class)
相似的还有norollbackFor,自定义不回滚的异常。
3. 数据库引擎要支持事务,若是是mysql,注意表要使用支持事务的引擎,好比innodb,若是是myisam,事务是不起做用的。
4. 是否开启了对注解的解析
<tx:annotation-driven transaction-manager="transactionManager" proxy-target class="true"/>
5. spring是否扫描到你这个包,以下是扫描到org.test下面的包<context:component-scan base-package="org.test" ></context:component-scan>

@Controller 用来响应页面,@Controller必须配合模版来使用。异步

@RestController Spring4以后新加入的注解,原来返回json须要@ResponseBody和@Controller配合。

@RequestBody 将接收的json数据装载到实体类中。

@RequestMapping 配置url映射

@PathVaribale 获取url中的数据

@RequestParam 获取请求参数的值

@RequestBody 用于接收实体类

@RequestAttribute 用于接收,被拦截后设置的属性

@GetMapping 组合注解

@PostConstruct与@PreDestroy详解及实例

@PostConstruct注释的方法,会在构造方法以后,init方法以前进行调用。
只有一个方法可使用此注释进行注解;
被注解方法不得有任何参数;
被注解方法返回值为void;
被注解方法不得抛出已检查异常;
被注解方法需是非静态方法;
此方法只会被执行一次;
PreDestroy 注释做为回调通知用于各方法,以表示该实例正处于被容器移除的过程当中。用 PreDestroy 注释的方法一般用于释放它已持有的资源。

@PropertySource 注解能够从properties文件中,获取对应的key-value值,将其赋予变量;

@ConfigurationProperties的大体做用就是经过它能够把properties或者yml配置直接转成对象。

@RunWith:这个是指定使用的单元测试执行类,这里就指定的是SpringJUnit4ClassRunner.class;

@webservice:

类上加上@WebService注解
@WebMethod注解声明了这个方法是要发布出去的方法

@Resource 默认是按照名称来装配注入的,只有当找不到与名称匹配的bean才会按照类型来注入。它有两个属性是比较重要的:

①. name: Spring 将 name 的属性值解析为 bean 的名称, 使用 byName 的自动注入策略
②. type: Spring 将 type的属性值解析为 bean 的类型,使用 byType 的自动注入策略
注: 若是既不指定 name 属性又不指定 type 属性,Spring这时经过反射机制使用 byName 自动注入策略
@Resource 的装配顺序
  1. 若是同时指定了 name 属性和 type 属性,那么 Spring 将从容器中找惟一匹配的 bean 进行装配,找不到则抛出异常
    2. 若是指定了 name 属性值,则从容器中查找名称匹配的 bean 进行装配,找不到则抛出异常
    3. 若是指定了 type 属性值,则从容器中查找类型匹配的惟一的 bean 进行装配,找不到或者找到多个都会抛出异常
    4. 若是都不指定,则会自动按照 byName 方式进行装配, 若是没有匹配,则回退一个原始类型进行匹配,若是匹配则自动装配

@Autowried 默认是按照类型进行装配注入,默认状况下,它要求依赖对象必须存在,若是容许 null 值,能够设置它 required 为false。
  若是咱们想要按名称进行装配的话,能够添加一个 @Qualifier 注解解决。

demo
@Autowried
@Qualifier("adminDAO")
private AdminDAO adminDAO;

@Async和@EnableAsync为异步注解,放到方法上,表示调用该方法的线程与此方法异步执行,须要配合注解使用。@EnableAsync放在启动类上,Async放在方法上。

@JsonInclude(Include.NON_NULL) 是springmvc中的标注,是为了控制返回的json字符串显示哪些字段。这里的设置是为null的字段不显示

@ConfigurationProperties(prefix = "sso") 能够在实体类中将properties文件的值注入到属性中。

相关文章
相关标签/搜索