Spring常用注解

1.@Component在类定义之前添加@Component注解,它会被SpringIoC容器识别,并转为bean。

 2.@RepositoryDao实现类进行注解(特殊的@Component)。

 3.@Service用于对业务逻辑层进行注解(特殊的@Component)。

 4.@Controller用于控制层注解(特殊的@Component)。

 5.@RequestMapping:用于处理请求地址映射,可以作用于类和方法上。

       其属性有:value:定义request请求的映射地址

                 method:定义request地址的请求方式(GET/POST/HEAD/PUT/DELETE/OPTIONS/PATCH)

                 param:定义request请求中必须包含的参数值,一般作用于表单。

                 headers:定义request请求中必须包含某些指定的请求头,如text/html、text/plain等

                 consumes:定义请求提交内容的类型

                 produces:指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回

 6.@RequestParam:用于获取前台参数,一般作用于表单。

       其属性有:value:参数的名称required:定义传入的该参数是否为必须,默认为true

 7.@RequestBody:用于获取前台参数,一般作用于ajax、json。

 8.@PathVariable:用于接收浏览器地址中QueryString的参数。

      其属性有:value:参数的名称required:轻易传入参数是否为必须

 9.@ResponseBody:作用于方法上,将整个返回结果以某种格式返回,如json或xml。

 10.@CookieValue:用于获取请求的Cookie值。

 11.@ModelAttribute:用于把参数保存到model中,可以注解方法或参数,注解在方法上的时候,该方法将在处理器方法执行之前执行,然后把返回的对象存放在session(前提是要有@SessionAttributes注解)或模型属性,注解在标注方法的时候指定,如果没有指定,则使用返回类型的类名称作为属性名称。

 12.@SessionAttributes:用于使得模型中的数据存储一份到session域中,配合@ModelAttribute使用的时候,会将对应的名称的model值存到session中。

 13.@Autowired:自动注入,如果按照byName来装配,可以结合@Qualifier注解一起使用。

 15.@RestController:使得当前的Controller层返回的全部都是Json类型的数据。

 16.@Transactional:将类中的方法变为事务。

        其属性有:readOnly=false,意思为不为只读,可以进行增删改查

                   propagation=Propagation.REQUIRED,传播行为

@Transactional(readOnly = false, rollbackFor = Exception.class)

 17.@bean:等同于在spring配置文件中配置的bean....。

 18.@Configuration:用于定义配置类,可替换xml配置文件。

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

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

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

@RestController:用于标注控制层组件(如struts中的action),@ResponseBody和@Controller的合集。

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

@EnableAutoConfiguration:SpringBoot自动配置(auto-configuration):尝试根据你添加的jar依赖自动配置你的Spring应用。例如,如果你的classpath下存在HSQLDB,并且你没有手动配置任何数据库连接beans,那么我们将自动配置一个内存型(in-memory)数据库”。你可以将@EnableAutoConfiguration或者@SpringBootApplication注解添加到一个@Configuration类上来选择自动配置。如果发现应用了你不想要的特定自动配置类,你可以使用@EnableAutoConfiguration注解的排除属性来禁用它们。

@ComponentScan:表示将该类自动发现扫描组件。个人理解相当于,如果扫描到有@Component、@Controller、@Service等这些注解的类,并注册为Bean,可以自动收集所有的Spring组件,包括@Configuration类。我们经常使用@ComponentScan注解搜索beans,并结合@Autowired注解导入。可以自动收集所有的Spring组件,包括@Configuration类。我们经常使用@ComponentScan注解搜索beans,并结合@Autowired注解导入。如果没有配置的话,Spring Boot会扫描启动类所在包下以及子包下的使用了@Service,@Repository等注解的类。

@Configuration:相当于传统的xml配置文件,如果有些第三方库需要用到xml文件,建议仍然通过@Configuration类作为项目的配置主类——可以使用@ImportResource注解加载xml配置文件。

@Import:用来导入其他配置类。(java导包)

@ImportResource:用来加载xml配置文件。

@Autowired:自动导入依赖的bean

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

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

@Bean:用@Bean标注方法等价于XML中配置的bean。

@Value:注入Spring boot application.properties配置的属性的值。示例代码:

@Inject:等价于默认的@Autowired,只是没有required属性;

@Component:泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。

@Bean:相当于XML中的,放在方法的上面,而不是类,意思是产生一个bean,并交给spring管理。

@AutoWired:自动导入依赖的bean。byType方式。把配置好的Bean拿来用,完成属性、方法的组装,它可以对类成员变量、方法及构造函数进行标注,完成自动装配的工作。当加上(required=false)时,就算找不到bean也不报错。

@Qualifier:当有多个同一类型的Bean时,可以用@Qualifier(“name”)来指定。与@Autowired配合使用。@Qualifier限定描述符除了能根据名字进行注入,但能进行更细粒度的控制如何选择候选者,具体使用方式如下:

@Resource(name=”name”,type=”type”):没有括号内内容的话,默认byName。与@Autowired干类似的事。

@RequestMapping:@RequestMapping(“/path”)表示该控制器处理所有“/path”的UR L请求。RequestMapping是一个用来处理请求地址映射的注解,可用于类或方法上。

用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。该注解有六个属性:

params:指定request中必须包含某些参数值是,才让该方法处理。

headers:指定request中必须包含某些指定的header值,才能让该方法处理请求。

value:指定请求的实际地址,指定的地址可以是URI Template 模式

method:指定请求的method类型, GET、POST、PUT、DELETE等

consumes:指定处理请求的提交内容类型(Content-Type),如application/json,text/html;

produces:指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回

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

@RequestParam

String a =request.getParameter(“a”)。

@PathVariable:路径变量。如参数与大括号里的名字一样要相同。

@MapperScan@mapper

在不使用@MapperScan前,我们需要直接在Mapper类上面添加注解@Mapper,这种方式要求每一个Mapper类都需要添加此注解,非常麻烦,属于重复劳动。通过使用@MapperScan注解,可以让我们不用为每个Mapper类都添加@Mapper注解。

@SpringBootApplication 

@MapperScan({"cn.mybatis.mappers.class","cn.mybatis.mappers.student"}) 

public class SpringbootMybatisDemoApplication{ 

    public static void main(String[] args) { 

       SpringApplication.run(SpringbootMybatisDemoApplication.class, args); 

    } 

}

目前框架上是两个注解都在使用

五、全局异常处理

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JAVA代码搬运工

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值