Spring注解

  • @SpringBootApplication:申明让spring boot自动给程序进行必要的配置,这个配置等同于:@Configuration ,@EnableAutoConfiguration 和 @ComponentScan 三个配置。

    @Configuration 等同于spring的XML配置文件;使用Java代码可以检查类型安全。
    @EnableAutoConfiguration 自动配置。
    @ComponentScan 让spring Boot扫描到Configuration类并把它加入到程序上下文。
    @ComponentScan 组件扫描,可自动发现和装配一些Bean。

  • @Controller:用于标注控制器层组件

  • @Service:用于标注业务层组件

  • @Component : 用于标注这是一个受 Spring 管理的组件,组件引用名称是类名,第一个字母小写。可以使用@Component(“beanID”) 指定组件的名称。@Component可配合CommandLineRunner使用,在程序启动后执行一些基础任务。

  • @Repository:用于标注数据访问组件,即DAO组件

  • @Bean:方法级别的注解,主要用在@Configuration和@Component注解的类里,@Bean注解的方法会产生一个Bean对象,该对象由Spring管理并放到IoC容器中。引用名称是方法名,也可以用@Bean(name = “beanID”)指定组件名

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

    @ResponseBody:表示该方法的返回结果直接写入HTTP response body中,一般在异步获取数据时使用,用 于构建RESTful的api。在使用@RequestMapping后,返回值通常解析为跳转路径,加上@esponsebody后返回结果不会被解析为跳转路径,而是直接写入HTTP response body中。比如异步获取json数据,加上@Responsebody后,会直接返回json数据。该注解一般会配合@RequestMapping一起使用。

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

  • @RequestMapping:提供路由信息,负责URL到Controller中的具体函数的映射。

    @GetMapping:获取信息
    @PostMapping:创建信息
    @DeleteMapping:删除信息
    @PutMapping:更新信息
    @PatchMapping:Patch方式是对put方式的一种补充;put方式是可以更新.但是更新的是整体.patch是对局部更新;

  • @Autowired 按类型自动导入。在容器查找匹配的Bean,当有且仅有一个匹配的Bean时,Spring将其注入@Autowired标注的变量中。

  • @Resource:按名称自动装配。@Resource和@Autowired都是做bean的注入时使用。

    @Autowired为Spring提供的注解,需要导入包org.springframework.beans.factory.annotation.Autowired;只按照byType(类型)注入。

    @Resource默认按照ByName(名称)自动注入,并不是Spring的注解,由J2EE提供,需要导入包javax.annotation.Resource。@Resource有两个重要的属性:name和type,而Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的
    类型。

在这里插入图片描述


简单点说,就是,能够明确该类是一个控制器类组件的,就用@Controller;能够明确是一个服务类组件的,就用@Service;能够明确该类是一个数据访问组件的,就用@Repository;不知道他是啥或者不好区分他是啥,但是就是想让他动态装配的就用@Component。
@Controller、@Service、@Component、@Repository都是类级别的注解,如果一个方法也想动态装配,就用@Bean。
当我们想按类型进行自动装配时,就用@Autowired;当我们想按名称(beanID)进行自动装配时,就用@Resource;当我们需要根据比如配置信息等来动态装配不同的组件时,可以用getBean(“beanID”)。

【转载】深入理解Spring两大特性:IoC和AOP


  • @PathVariable获取参数。

  • @JsonBackReference解决嵌套外链问题。

  • @RepositoryRestResourcepublic配合spring-boot-starter-data-rest使用。

  • @Data:该注解用在类上,帮类提供了getXxx()、setXxx()方法、equals()、hashCode()、toString() 这些方法。也就是说只要类上写了这个注解,那就不需要再生成get、set、toString等方法了

  • @JsonIgnore:此注解用于属性或者方法上(最好是属性上),用来完全忽略被注解的字段和方法对应的属性;返回的json数据即不包含该属性。

  • @Api()用于类:表示标识这个类是swagger的资源

  • @Slf4j:用作日志输出的,一般会在项目每个类的开头加入该注解,如果不写下面这段代码,并且想用log private final Logger logger = LoggerFactory.getLogger(当前类名.class);就可以用@Slf4来代替;这样就省去这段很长的代码。

  • @RequestParam:将请求参数区域的数据映射到控制层方法的参数上
    在这里插入图片描述

  • @PostConstruct注解在方法上,表示此方法是在Spring实例化该Bean之后马上执行此方法,之后才会去实例化其他Bean,并且一个Bean中@PostConstruct注解的方法可以有多个。
    被@PostConstruct修饰的方法会在构造函数之后,init()方法之前运行,并且只会被服务器调用一次。

【参考文档】
Spring注解大全

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值