@RestController和@Controller的区别

本文详细介绍了在SpringBoot项目中使用@Controller与@RestController的区别,包括如何正确地返回页面及JSON数据等内容。

今天在学习使用Spring Boot的Thymeleaf模板时,遇到了一个问题:本想要跳转到指定的页面,结果显示的确实return的返回值:
最初的代码
页面显示结果
看到这个之后,纳闷了很久,也许是本人比较“菜”吧,没有想到原因,于是上网查了一下,说是不能使用@RestController:
这里写图片描述
于是乎,就有了这篇博客^_^
@Controller和@RestController的区别主要有以下几点:
1. @RestController相当于@Controller和@ResponseBody合在一起的作用;
2. 如果使用@RestController注解Controller层的话,则返回的是return里面的内容,无法返回到指定的页面,配置的视图解析器InternalResourceViewResolver也就自然没有作用了;
3. 如果要返回到指定的页面,则需要用@Controller配合视图解析器InternalResourceViewResolver;
4. 如果需要返回JSON、XML或自定义mediaType内容到页面,则需要在对应的方法上加上@ResponseBody注解。
这里写图片描述
修改过后的代码
最终的页面效果图
@Controller和@RestController的主要区别就这么多了,有不对的地方,还请大神多多指教!!!

### 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值