@RestController和@Controller的区别

本文探讨了Spring框架中@Controller与@ResponseBody注解的使用方法。详细解释了如何通过这两个注解实现页面跳转与JSON数据返回,以及@RestController注解的含义与用途。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用@Controller 注解,在对应的方法上,视图解析器可以解析return 的jsp,html页面,并且跳转到相应页面
若返回json等内容到页面,则需要加@ResponseBody注解。
如果你的代码写的如下:

@Controller
@RequestMapping(value = "/test",method = RequestMethod.GET)
public class TestController {

    @RequestMapping(value = "/a",method = RequestMethod.GET)
    public String probe(){
        System.out.println("good");
        return "success";
    }
}

实际上以上代码,是可以在控制台打印出good来的,但是postman中却显示了404

{
    "timestamp": 1539250958530,
    "status": 404,
    "error": "Not Found",
    "message": "No message available",
    "path": "/test/a"
}

原因就是没有success.jsp页面,所以报错。解决办法:在RequestMapping中加上@ResponseBody就可以解决。
当然,你在类上使用@RestController也解决了这个问题,返回了success.

@RestController注解,相当于@Controller+@ResponseBody两个注解的结合,返回json数据不需要在方法前面加@ResponseBody注解了,但使用@RestController这个注解,就不能返回jsp,html页面,视图解析器无法解析jsp,html页面

### 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、付费专栏及课程。

余额充值