@RestController和@Controller的区别

        根据下图的class文件,我们可以看出@RestController是一个复合注解,其中主要复合了@Controller和@ResponseBody。

@Controller:表示该类是controller层的bean,可以告诉容器来创建该类,并放到容器中,需要使用时直接来拿就可以。

@ResponseBody:表明该类的所有方法的返回值都直接进行提交而不经过视图解析器,且返回值的数据自动封装为json的数据格式(有利于ajax接受json数据,展示到前端)

@RestController:包含复合注解的功能,并且使用该注解时,请求的风格一般会采用RESTful的风格

REST(英文:Representational State Transfer,简称 REST)

        任何的技术都可以实现这种理念,如果一个架构符合 REST 原则,就称它为 RESTFul 架构。
比如我们要访问一个 http 接口:http://localhost:8080/boot/order?id=1021&status=1
采用 RESTFul 风格则 http 地址为:http://localhost:8080/boot/order/1021/1
RESTful常用的注解
1) @PathVariable
获取 url 中的数据
该注解是实现 RESTFul 最主要的一个注解,例如:
/**
     * @PathVariable(路径变量):获取url中的数据
     *      属性:value :路径变量名
     *      位置:放在控制器方法的形参的前面
     *
     *  http://localhost:8080/myboot/student/1002
     */
    @GetMapping("/student/{stuId}")
    public String queryStudent(@PathVariable(value = "stuId") Integer studentId){

        return "查询学生stuId="+studentId;
    }

通过@PathVariable标注的变量可以将变量直接跟在http后面,不需要像传统的http一样变量要跟在?后面。更加美观便捷。

2) @PostMapping
接收和处理 Post 方式的请求
3) @DeleteMapping
接收 delete 方式的请求,可以使用 GetMapping 代替
4) @PutMapping
接收 put 方式的请求,可以用 PostMapping 代替
5) @GetMapping
接收 get 方式的请求
### Spring Boot `@RestController` vs `@Controller` 注解区别及用法 #### 区分注解功能 `@RestController` `@Controller` 都是用于定义控制器层组件的关键注解,然而两者有着不同的应用场景特性。 - **`@Controller` 注解** 这一注解通常应用于传统的 MVC 控制器场景,在这种情况下,返回视图名称并携带模型数据给前端页面。为了实现 RESTful API 接口响应 JSON 或 XML 数据的需求,则需额外配合 `@ResponseBody` 来指定方法返回的内容直接写入 HTTP 响应体中[^1]。 - **`@RestController` 注解** 此注解专为开发 RESTful Web Service 设计,其内部已经包含了 `@Controller` `@ResponseBody` 的效果,因此当使用此注解时无需再单独声明 `@ResponseBody` 即可让方法返回的对象自动序列化成 JSON 或者 XML 形式的字符串作为 HTTP Response Body 返回给客户端[^3]。 #### 实际应用案例展示 下面通过具体的代码实例来进一步说明两者的不同之处: ##### 使用 `@Controller` ```java import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.GetMapping; @Controller public class MyWebController { @GetMapping("/hello") public String hello(Model model){ model.addAttribute("message", "Hello, world!"); return "index"; // 返回模板名 } } ``` 在这个例子中,`MyWebController` 类被标记为 `@Controller` 并且有一个处理 GET 请求的方法 `/hello` 。该方法向 Model 添加了一个属性 message 后返回一个逻辑视图名为 `"index"` ,这表明服务器端会渲染相应的 JSP/Thymeleaf 页面并将其中的数据填充进去显示给用户。 ##### 使用 `@RestController` ```java import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.*; @RestController @RequestMapping("/api/v1/greetings") public class GreetingApiController { @GetMapping("/{name}") public ResponseEntity<Greeting> greet(@PathVariable String name) { var greeting = new Greeting(String.format("Hello %s!", name)); return ResponseEntity.ok(greeting); } } class Greeting{ private final String content; public Greeting(String content) { this.content = content; } public String getContent() { return content; } } ``` 这里展示了如何利用 `@RestController` 创建 RESTful API 接口。每当收到匹配路径模式 `/api/v1/greetings/{name}` 下的请求时就会调用对应的方法,并将结果对象转换成 JSON 格式发送回客户端。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

造化圣者

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

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

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

打赏作者

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

抵扣说明:

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

余额充值