springboot常用注解

一、@Controller

@Controller 是标记在Controller 类(包和类名之间)上面的。用于指示Spring类的实例是一个控制器。Controller接口的实现类只能处理一个单一请求动作,而@Controller注解的控制器可以支持同时处理多个请求动作,更加灵活。
Spring使用 扫描机制 查找应用程序中所有基于注解的控制器类。分发处理器 会扫描使用了该注解的类的方法,并检测该方法是否使用了@RequestMapping注解,而使用@RequestMapping注解的方法才是真正处理请求的处理器。

二、@RestController

1、语法说明

@RestController相当于@ResponseBody+@Controller
@Controller注解,表明了这个类是一个控制器类。
@ResponseBody表示方法的返回值直接以指定的格式写入Http response body中,而不是解析为跳转路径。 假如是字符串则直接将字符串写到客户端,假如是一个对象,此时会将对象转化为json串然后写到客户端。
@RestController:用在类上,代表该类是一个控制类,类中所有函数的返回值均以String的形式呈现在页面中。
https://www.cnblogs.com/yaqee/p/11256047.html

2、使用场景
image.png

三、@RequestMapping("/test")

1、语法说明

对前端的URL请求进行路由解析分配。

①将 @RequestMapping 注解在类中方法上,而Controller类上不添加 @RequestMapping 注解,这时的请求 URL 是相对于 Web 根目录。

②将 @RequestMapping 注解在Controller 类上,这时类的注解是相对于 Web 根目录,而方法上的是相对于类上的路径。

@RequestMapping 中的 value 和 path 属性(这两个属性作用相同,可以互换),@PathVariable 将 URL 中的占位符绑定到控制器的处理方法的参数中,占位符使用{}括起来。

四、@Repository

1、语法说明
  • @repository是用来注解dao接口,这个注解是将接口UserDao的一个实现类交给spring管理(在spring中有开启对@repository注解的扫描),当哪些地方需要用到这个实现类作为依赖时,就可以注入了。
  • repository原意指的是仓库,即数据仓库的意思。Repository居于业务层和数据层之间,将两者隔离开来,在它的内部封装了数据查询和存储的逻辑。
  • @Repository注解修饰哪个类,则表明这个类具有对对象进行CRUD(增删改查)的功能,而且@Repository是@Component注解的一个派生品,所以被@Repository注解的类可以自动的被@ComponentScan 通过路径扫描给找到。(这也在一定程度上解释了,为什么被@Repository注解的类也能@Autowired)
2、使用场景
image.png

五、参数绑定相关注解.

https://www.cnblogs.com/morethink/p/8028664.html
https://www.cnblogs.com/fobei/p/5603447.html
https://cloud.tencent.com/developer/article/1414464

image.png

1、@Pathvariable

restful风格:通过url来获取参数。

    //访问格式 http://localhost:9000/testRequest/55
     @RequestMapping("/testRequest/{sid}")
    public String testRequest(@PathVariable("sid") String id){
        //@PathVariable("sid") 将url中的sid赋值给c参数id
        System.out.println(id);
        return id;
    }
image.png
2、@RequestParam

注解@RequestParam接收的参数是来自requestHeader中,即请求头。通常用于GET请求,像POST、DELETE等其它类型的请求也可以使用。
该注解常用来处理Content-Type: 是application/x-www-form-urlencoded编码的内容。

  @RequestMapping("/testRequest")
    public String testRequest(@RequestParam("sid") String id){
        //@RequestParam,注意url中的参数应该与string id匹配,否则应该在RequestParam的value属性中引入
        System.out.println(id);
        return id;
    }
image.png
3、@RequestBody

注解@RequestBody接收的参数是来自requestBody中,即请求体。一般用于处理非 Content-Type: application/x-www-form-urlencoded编码格式的数据,比如:application/json、application/xml等类型的数据。
就application/json类型的数据而言,使用注解@RequestBody可以将body里面所有的json数据传到后端,后端再进行解析。

 @RequestMapping("/testRequest")
    public String testRequest(@RequestBody String id){
        //@RequestBody,将body中的json串赋值给了string id,并不会自动筛选匹配
        System.out.println(id);
        return id;
    }
image.png

你可能感兴趣的:(springboot常用注解)