@RestController 和 @Controller 的区别

本文深入探讨了@RestController注解的作用,它如何简化JSON数据的处理,以及与@Controller注解的区别。通过示例代码展示了如何使用@RequestBody和@ResponseBody进行数据交互。

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

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

理解下面的注解哦。

@ResponseBody 表示该方法的返回结果直接写入 HTTP response body 中,一般在异步获取数据时使用【也就是AJAX】,在使用 @RequestMapping后,返回值通常解析为跳转路径,但是加上 @ResponseBody 后返回结果不会被解析为跳转路径,而是直接写入 HTTP response body 中。 比如异步获取 json 数据,加上 @ResponseBody 后,会直接返回 json 数据。@RequestBody 将 HTTP 请求正文插入方法中,使用适合的 HttpMessageConverter 将请求体写入某个对象。

 

撸代码:

//@RestController
@Controller
@RequestMapping("falarmUser")
public class FAlarmUserController {

    private static final Logger logger = LoggerFactory.getLogger(FAlarmUserController.class);

    @Autowired
    private FAlarmUserService fAlarmUserService;

    /**
     * 添加用户
     * @param userEntity
     * @return
     */
    @PostMapping("addUser")
    public Object addUser(@RequestBody FAlarmUserEntity userEntity){
        logger.info("添加成员的信息 : "+userEntity.toString());
        Response res = new Response();
        res = fAlarmUserService.addUser(userEntity);
        return res;
    }

}

Response 类:

@JsonInclude(value = JsonInclude.Include.NON_EMPTY)
public class Response implements Serializable {

    private static final long serialVersionUID = 1L;

    private Integer code;

    private Object data;

    private String message;

    public Response() {
        super();
    }

    public Integer getCode() {
        return code;
    }

    public void setCode(Integer code) {
        this.code = code;
    }

    public Object getData() {
        return data;
    }

    public void setData(Object data) {
        this.data = data;
    }

    public String getMessage() {
        return message;
    }

    public void setMessage(String message) {
        this.message = message;
    }
}

如果是用@RestController ,请求之后返回的结果如下。

如果使用 @Controller,返回结果 如下;

@Controller 注解不能将结果写入到  HTTP response body 中,因而无法正常显示。

 

### 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 格式发送回客户端。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值