水下功夫做透,水上才能顺风顺水。

spring boot 注解

@RequestMapping 提供路由信息。

@Controller 用于定义控制器类,在spring 项目中由控制器负责将用户发来的URL请求转发到对应的服务接口(service层),一般这个注解在类中,通常方法需要配合注解@RequestMapping。

@ResponseBody 表示该方法的返回结果直接写入HTTP response body中。

一般在异步获取数据时使用,在使用@RequestMapping后,返回值通常解析为跳转路径,加上
@responsebody后返回结果不会被解析为跳转路径,而是直接写入HTTP response body中。比如
异步获取json数据,加上@responsebody后,会直接返回json数据。

@RestController    告诉Spring以字符串的形式渲染结果,并直接返回给调用者。

是@Controller和@ResponseBody的合集,表示这是个控制器bean,并且是将函数的返回值直接填入HTTP响应体中,是REST风格的控制器。

注意:RestController 和 RequestMapping 注解是Spring MVC注解,不是spring boot 特定部分。

@EnableAutoConfiguration 这个注解告诉Spring Boot根据添加的jar依赖猜测你想如何配置Spring。

由于 spring-boot-starter-web 添加了Tomcat和Spring MVC,所以auto-configuration将假定你正在开发一个web应用并相应地对Spring进行设置。

Starter POMs和Auto-Configuration:设计auto-configuration的目的是更好的使用"Starter POMs",但这两个概念没有直接的联系。你可以自由地挑选starter POMs以外的jar依赖,并且Spring Boot将仍旧尽最大努力去自动配置你的应用。

如果发现应用了你不想要的特定自动配置类,你可以使用 @EnableAutoConfiguration 注解的排除属性来禁用它们。

@EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})

@AutoWired 把配置好的Bean拿来用,完成属性、方法的组装,它可以对类成员变量、方法及构造函数进行标注,完成自动装配构造的工作。

当加上(required=false)时,就算找不到bean也不报错。

@Component 泛指组件。当组件不好归类的时候,我们可以使用这个注解进行标注。一般公共的方法我会用上这个注解。

@RequestParam  用在方法的参数前面。

@RequestParam String a =request.getParameter("a");

@PathVariable 路径变量。

RequestMapping("user/get/mac/{macAddress}") public String getByMacAddress(@PathVariable String macAddress){ //do something;}

@value 注解来读取application.properties里面的配置

1 # face++ key 
2 face_api_key = R9Z3Vxc7ZcxfewgVrjOyrvu1d-qR**** 
3 face_api_secret =D9WUQGCYLvOCIdsbX35uTH********
1 @Value("${face_api_key}")     
2 private String API_KEY;       
3 @Value("${face_api_secret}")    
4 private String API_SECRET;

注意:使用這個注解的时候 使用@Value的类如果被其他类作为对象引用,必须要使用注入的方式,而不能new。这个很重要,我就是被这个坑了

@ExceptionHandler(Exception.class): 用在方法上面表示遇到这个异常就执行以下方法。

@ControllerAdvice  包含@Component。可以被扫描到。 统一处理异常。

@Profiles  Spring Profiles提供了一种隔离应用程序配置的方式,并让这些配置只能在特定的环境下生效。

任何@Component或@Configuration都能被@Profile标记,从而限制加载它的时机。

@Configuration 
@Profile("production") 
public class ProductionConfiguration {
 // ...
}

 @ImportResource 注解加载xml配置文件。

@SpringBootApplication  该注解等价于以默认属性使用 @Configuration , @EnableAutoConfiguration 和 @ComponentScan 。申明让spring boot自动给程序进行必要的配置。

很多Spring Boot开发者总是使用 @Configuration , @EnableAutoConfiguration 和 @ComponentScan 注解他们的main类。由于这些注解被如此频繁地一块使用(特别是你遵循以上最佳实践时),Spring Boot提供一个方便的 @SpringBootApplication 选择。 其中@ComponentScan让spring Boot扫描到Configuration类并把它加入到程序上下文。

@Configuration 等同于spring的XML配置文件;使用Java代码可以检查类型安全。  

@ComponentScan 组件扫描,可自动发现和装配一些Bean。

@Service 一般用于修饰service层的组件

@Repository 使用@Repository注解可以确保DAO或者repositories提供异常转译,这个注解修饰的DAO或者repositories类会被ComponetScan发现并配置,同时也不需要为它们提供XML配置项。

@Entity:@Table(name=”“):表明这是一个实体类。一般用于jpa这两个注解一般一块使用,但是如果表名和实体类名相同的话,@Table可以省略

@Column:如果字段名与列名相同,则可以省略。

@Id:表示该属性为主键

 

posted @ 2018-08-24 11:38  北方寒士  阅读(149)  评论(0编辑  收藏  举报