Spring中常用注解及其作用

1.@Component

它是这些注解里面最普通的一个注解,一般用于把普通pojo实例化到spring容器中。 @Controller和@Service和@Repository是它的特殊情况,当一个类不需要进行这几种特殊归类的时候,只是作为一个普通的类,被Spring管理就OK的时候,比较适合采用@Component注解。 原理:将普通JavaBean实例化到spring容器中,Spring容器统一管理,用起来不用自己new了,相当于配置文件中的< bean id="" class=""/>

2.@Controller

用于标注控制层,表示向控制层注入服务层的数据

3.@Service

用于标注服务层,来进行业务的逻辑处理,在服务层注入DAO层数据

4.@Repository

用于标注数据访问层,也可以说用于标注数据访问组件,即DAO组件

5.@ComponentScan

(这个注解长得和@Component有点像,但是他们是完全两个不同类型的注解,@Component像一个标签,标志着你这类是个啥,而@ComponentScan像一个路标,告诉你去哪找东西)

应用场景:在定义spring中的bean的时候,一般有两步 1.在bean上面添加@Controller/@Service/@Repository/@Component这几个注解,标注这个类是个bean 2.然后还需要让Spring能够找到这个bean,这时候就需要使用到@ComponentScan这个注解了

使用:@ComponentScan(“com.demo”) 引号里面是要扫描的包路径

SpringBoot中的使用: 在SpringBoot中也许不会经常看到这个注解,因为@SpringBootApplication这个注解里面集成了@ComponentScan注解,它里面会自动扫描这个类所在包以及子包下面的bean。 所以如果我们要找的bean不在它的所在包或者子包里面,就需要自己再添加一个@ComponentScan注解。例如: @ComponentScan({“com.demo.springboot”,”com.demo.somethingelse”})

6.@ResponseBody

加了这个注解的类会将controller的方法返回的对象通过适当的转换器转换为指定的格式之后,写入到response对象的body区,通常用来返回JSON数据或者是XML。

需要注意的是,在使用此注解之后的数据不会再走ViewResolver,而是直接将数据写入到输入流中,它的效果相当于用response对象输出指定格式的数据。

当它返回json串的时候,效果相当于:

response.getWriter.write(JSONObject.fromObject(对象).toString());

7.@RestController

@RestController = @Controller + @ResponseBody

写这一个注解就相当于写了后面的两个注解,在返回值是json串的非常方便,但同时也会有一个问题,加了这个注解就不能返回jsp或者html页面,这时可以通过返回视图数据的方式来返回页面。 例如:

ModelAndView mv = new ModelAndView("index"); return mv;

8.@RequestMapping(“xxxx”)

它用于 映射客户端的访问地址,可以被应用于类和方法上面,客户进行访问时,URL应该为类+方法上面的这个注解里面的内容。 例如: 下面这个类里面方法的访问地址就应该是:http://localhost:8080/AB @Controller @RequestMapping("/A") public class HelloWorld{

@RequestMapping("/B") public String helloworld(){ } }

格式:@RequestMapping(" ") 双引号里面默认是value的值, 所以@RequestMapping(value = “a”)等价于@RequestMapping(“a”)

除了value之外,@RequestMapping里面还有这些属性 里面经常用的有mehod,params,headers 分别为请求方法,请求参数,请求头。 它们之间是与的关系,联合使用会使得请求的映射更加精细

method:可以指定请求的类型。 http中规定请求有四种类型:get,post,put,delete。 例如:下面这种情况中,只有DELETE方式的helloworld请求才能够执行该处理方法。

@RequestMapping(value="/helloworld", method=RequestMethod.DELETE) public class helloworld{ }

params和headers支持简单的表达式: params1:表示请求必须包含名为params1的请求参数 !params1:表示请求不能包含名为params1的请求参数 params1 != value1:表示请求必须包含名为params1的请求参数,但是其值不能 是value1 {“params1 = value1”, “param2”}:表示请求必须包含名为params1和params2两个请求参数,且params1的值必须为value1

9.三种Ant风格的URL

/user/create?? 匹配/user/createAA、/user/createBB等URL (??匹配任意两个字符) user//createUser 匹配/user/aaa/createUser、/user/bbb/createUser等URL (匹配任意字符) /user//createUser 匹配/user/createUser、/user/aaa/bbb/createUser等URL (匹配任意多层路径)

10.RestFul风格的URL

使用 @PathVariable 获取到URL的{ }中参数 例如:

@RequestMapping("/delete/{id}") public String testPathVariable(@PathVariable("id") Integer id){ System.out.println("id = " + id);

return SUCCESS; }

posted @ 2021-09-12 09:58  晚风将至  阅读(690)  评论(0编辑  收藏  举报