@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文件的值注入到属性中。