赞
踩
@Controller:标注一个控制器组件类
@Service:标注一个业务层0组件类
@Repository:标注一个DAO组件类
@Component:标注一个普通的spring Bean类
注:@Component、@Repository、@Service、@Controller实质上属于同一类注解,用法相同,功能相同,区别在于标识组件的类型
@Configuration:把一个类作为一个IoC容器,它的某个方法头上如果注册了@Bean,就会作为这个Spring容器中的Bean
@Autowired:用于为类的属性、构造器、方法进行注值,默认情况下,其依赖的对象必须存在(bean可用),如果需要改变这种默认方式,可以设置其required属性为false。默认按类型装配,如果我们想使用按名称装配,可以结合@Qualifier注解一起使用。如:@Autowired@Qualifier("BeanName") ,存在多个实例时使用
@Resource:它并不属于spring的注解,而是来自于JSR-250。其默认情况下按照bean的名称进行注入,当找不到匹配项时会按照类型装配。当按照名称进行装配时,可以指定其name属性,倘若没有指定,注解标注在哪个字段上,其默认名称就是那个字段的名称
@PostConstruct :在构造方法和init方法(如果有的话)之间得到调用,且只会执行一次。
@PreDestory :注解的方法在destory()方法调用后得到执行
@RequestMapping:是一个用来处理请求地址映射的注解,可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径
@RequestParam:用于绑定request请求参数到指定的方法
@PathVariable:用于方法修饰方法参数,会将修饰的方法参数变为可供使用的uri变量(可用于动态绑定)
@Transactional:在处理dao层或service层的事务操作时,譬如删除失败时的回滚操作,可用到@Transactional注解
@Aspect:标明该类为切面类,并启用AspectJ注解,注:在使用时要同@Component一起使用,否则不会被扫描到加入容器
@Pointcut:定义切入点
@Before:定义前置通知,在目标方法执行前执行
@After:定义后置通知,在目标方法执行后执行,不论是目标方法执行正常后退出,还是抛出异常后退出,均会被执行
@Around:定义环绕通知,在目标方法执行前后嵌入相关业务逻辑.
@AfterReturning:目标方法执行正常退出后执行
@AfterThrowing:目标方法执行抛出异常后执行
注:@Aspect、@Pointcut、@Before、@Around、@After、@AfterReturning、@AfterThrowing属于spring aop模块
@Value:从properties文件中的取值赋给修饰的字段
@Primary:自动装配时当出现多个Bean候选者时,被注解为@Primary的Bean将作为首选者,否则将抛出异常
@Lazy:用于注解类,延迟初始化。
@Named:和@Component功能相同。@Named可以有值,如果没有值生成的Bean名称默认和类名相同
@RequestHeader,@CookieValue:处理request header部分的注解
@RequestParam:作用是提取和解析请求中的参数。@RequestParam支持类型转换,类型转换目前支持所有的基本Java
@RequestBody:有个默认属性required,默认是true,当body里没内容时抛异常
@SessionAttributes:即将值放到session作用域中,写在class上面。
@ModelAttribute:该Controller的所有方法在调用前,先执行此@ModelAttribute方法,可用于注解和方法参数中,可以把这个@ModelAttribute特性,应用在BaseController当中,所有的Controller继承BaseController,即可实现在调用Controller时,先执行@ModelAttribute方法
@ResponseBody: 该注解用于将Controller的方法返回的对象,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区。使用时机:返回的数据不是html标签的页面,而是其他某种格式的数据时(如json、xml等)使用
@Scope:配置bean的作用域,默认是单例模式,即@Scope("singleton").
注: singleton:单例,即容器里只有一个实例对象。
prototype:多对象,每一次请求都会产生一个新的bean实例,Spring不无法对一个prototype bean的整个生命周期负责,容器在初始化、配置、装饰或者是装配完一个prototype实例后,将它交给客户端,由程序员负责销毁该对象,不管何种作用域,容器都会调用所有对象的初始化生命周期回调方法,而对prototype而言,任何配置好的析构生命周期回调方法都将不会被调用
request:对每一次HTTP请求都会产生一个新的bean,同时该bean仅在当前HTTP request内有效
@RestController:@Controller + @ResponseBody。是2个注解的合并效果,即指定了该controller是组件,又指定方法返回的是String或json类型数据。
@ResponseStatus:用于修饰一个类或者一个方法,修饰一个类的时候,一般修饰的是一个异常类,当处理器的方法被调用时,@ResponseStatus指定的code和reason会被返回给前端。value属性是http状态码,比如404,500等。reason是错误信息
@ControllerAdvice:该注解作用对象为TYPE,包括类、接口和枚举等,在运行时有效,并且可以通过Spring扫描为bean组件。其可以包含由@ExceptionHandler、@InitBinder 和@ModelAttribute标注的方法,可以处理多个Controller类,这样所有控制器的异常可以在一个地方进行处理。
@ExceptionHandler:当一个Controller中有方法加了@ExceptionHandler之后,这个Controller其他方法中没有捕获的异常就会以参数的形式传入加了@ExceptionHandler注解的那个方法中
注:如果单使用@ExceptionHandler,只能在当前Controller中处理异常。但当配合@ControllerAdvice一起使用的时候,就可以摆脱那个限制,对所有controller层异常进行处理。
spring在注解在springboot中也可以使用,不过springboot又新添了一些注解
@SpringBootApplication:Springboot项目的入口类,启动类。
从源码中发现@SpringBootApplication源码中包含一下三个注解:
@SpringBootConfiguration:作用与@Configuration
作用相同,都是用来声明当前类是一个配置类.可以通过@Bean
注解生成IOC容器管理的bean.
@EnableAutoConfiguration:是springboot实现自动化配置的核心注解,通过这个注解把spring应用所需的bean注入容器中
@ComponentScan:动态确定自动扫描范围,类型已经不扫描的类型.默认情况下:它扫描所有类型,并且扫描范围是@ComponentScan注解所在配置类包及子包的类
@GetMapping: 等同于 @RequestMapping(method = RequestMethod.GET)
@PostMapping :等同于 @RequestMapping(method = RequestMethod.POST)
@PutMapping :等同于 @RequestMapping(method = RequestMethod.PUT)
@DeleteMapping: 等同于 @RequestMapping(method = RequestMethod.DELETE)
@PatchMapping :等同于 @RequestMapping(method = RequestMethod.PATCH)
@RunWith(SpringRunner.class) :RunWith就是一个运行器,@RunWith(JUnit4.class)就是指用JUnit4来运行,@RunWith(SpringJUnit4ClassRunner.class),让测试运行于Spring测试环境,@RunWith(Suite.class)的话就是一套测试集合,
@SptingBootTest:是springboot 用于测试的注解,可指定启动类或者测试环境等
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。