【SpringBoot】带你一文彻底搞懂RestController和Controller的关系与区别

目录

什么是@RestController,什么是@Controller  

使用@ResponseBody注解让方法返回值作为响应内容是什么意思

举例说明

@RestController

@Controller

什么时候需要返回的是视图,什么时候需要返回数据?

当设计 RESTful API 时,一般的原则是:

下面是一些示例情况:

再以实例说明,更通俗易懂的理解:

总结


什么是@RestController,什么是@Controller  

    @RestController@Controller 是 Spring Framework 中用于定义控制器的注解。

    @RestController 是一个组合注解它结合了 @Controller@ResponseBody 注解的功能(就相当于把两个注解组合在一起)。在使用 @RestController 注解标记的类中,每个方法的返回值都会以 JSON 或 XML 的形式直接写入 HTTP 响应体中,相当于在每个方法上都添加了 @ResponseBody 注解。

    @Controller 注解标记的类则是传统的控制器类。它用于处理客户端发起的请求,并负责返回适当的视图(View)作为响应。在使用 @Controller 注解的类中,通常需要在方法上使用 @ResponseBody 注解来指示该方法的返回值要作为响应的主体内容,而不是解析为视图。

        简而言之,@RestController 适用于构建 RESTful 风格的 API,其中每个方法的返回值会直接序列化为 JSON 或 XML 数据并发送给客户端。而 @Controller 适用于传统的 MVC 架构,它负责处理请求并返回相应的视图。(@RestController下的方法默认返回的是数据格式,@Controller注解标注的类下面的方法默认返回的就是以视图为格式

使用@ResponseBody注解让方法返回值作为响应内容是什么意思

        在使用 @Controller 注解标记的类中,默认情况下,方法的返回值会被解析为一个视图名称,并寻找与该名称匹配的视图进行渲染。这意味着返回的结果会被解析为一个 HTML 页面或者模板引擎所需的数据。

        但是有时候需要将方法的返回值直接作为响应的主体内容,而不是解析为视图。为了实现这个目的,我们可以在方法上使用 @ResponseBody 注解。

  @ResponseBody 注解表示方法的返回值应该直接写入 HTTP 响应体中,而不是被解析为视图。它告诉 Spring MVC 框架将方法的返回值序列化为特定格式(如 JSON、XML 等)并作为响应的主体内容返回给客户端。

下面是一个使用 @Controller@ResponseBody 的示例:

@Controller
@RequestMapping("/hello")
public class HelloController {
    @GetMapping
    @ResponseBody
    public String sayHello() {
        return "Hello, World!";
    }
}

        当客户端发起 /hello 的 GET 请求时,sayHello() 方法会返回一个字符串 "Hello, World!"。因为在方法上使用了 @ResponseBody 注解,返回值不会被解析为视图,而是直接作为响应的主体内容返回给客户端。

举例说明

        现在假设有一个简单的订单系统,其中有一个功能是获取订单信息。我们来看如何使用 @RestController@Controller 分别实现同一个功能:

@RestController

@RestController
@RequestMapping("/orders")
public class OrderController {
    @GetMapping("/{id}")
    public Order getOrderById(@PathVariable int id) {
        // 从数据库中获取订单信息
        Order order = orderService.getOrderById(id);
        return order;
    }
}

        使用 @RestController 注解标记类,并在方法上使用 @GetMapping 注解定义了一个 GET 请求的处理方法。方法的返回值是 Order 类型的对象,它将会直接序列化为 JSON 格式的数据,并作为 HTTP 响应的主体内容返回给客户端。

@Controller

@Controller
@RequestMapping("/orders")
public class OrderController {
    @GetMapping("/{id}")
    @ResponseBody
    public ModelAndView getOrderById(@PathVariable int id) {
        // 从数据库中获取订单信息
        Order order = orderService.getOrderById(id);
        ModelAndView modelAndView = new ModelAndView("order-details");
        modelAndView.addObject("order", order);
        return modelAndView;
    }
}

        使用 @Controller 注解标记类,并在方法上使用 @GetMapping 注解定义了一个 GET 请求的处理方法。方法的返回值是 ModelAndView 类型的对象,它将包含要渲染的视图名称和需要传递给视图的数据。在方法上使用 @ResponseBody 注解,表示方法的返回值应该作为响应的主体内容,而不是解析为视图。

        通俗一点说就是——有时候并不需要返回视图,只需要一组数据,这样在方法加上一个@ResponseBody,就可以让返回的格式转换为数据格式

什么时候需要返回的是视图,什么时候需要返回数据?

当设计 RESTful API 时,一般的原则是:

  • 如果客户端希望获取数据(例如 JSON、XML),则返回数据。
  • 如果客户端希望展示数据(例如 HTML 页面),则返回视图。

下面是一些示例情况:

  • 当你在开发一个单页应用的后端接口时,前端通常会通过 Ajax 请求获取数据(例如 JSON),然后使用 JavaScript 动态更新页面。在这种情况下,你应该返回数据(例如使用 @ResponseBody 注解)。
  • 当你需要为前端渲染 HTML 页面时,需要返回视图。视图可以包含动态生成的数据,但最终会经过服务器端模板引擎的处理,形成最终的 HTML 页面。

再以实例说明,更通俗易懂的理解:

  1. 需要返回视图的实例: 假设你正在开发一个博客应用的后端接口。有一个页面需要显示所有文章的列表,并且希望以 HTML 形式展示。在这种情况下,你可以设计一个 GET 请求的接口 /api/articles,返回一个包含所有文章数据的视图,让前端直接展示这个页面。这里需要返回视图而不是仅返回数据,因为需要服务端渲染整个 HTML 页面。

  2. 只需要返回数据的实例: 假设正在开发一个电子商务网站,前端使用 React 或 Vue.js 等框架构建。在购物车页面上,需要获取当前用户的购物车数据以便展示。在这种情况下,你可以设计一个 GET 请求的接口 /api/cart,返回一个 JSON 对象,包含当前用户的购物车数据。这里只需要返回数据而不是整个 HTML 页面,因为前端通过 JavaScript 来处理和展示数据。

总结

  • @RestController 是 @Controller 和 @ResponseBody 的组合注解,用于创建 RESTful 风格的 API。
  • @RestController 返回的数据会直接作为响应的主体内容(JSON 或 XML),不进行页面跳转或视图解析。
  • @Controller 用于传统的 MVC 架构,负责处理请求并返回视图作为响应。
  • @Controller 方法通常需要配合 @ResponseBody 注解,才能将返回值作为响应的主体内容。
  • 传统的springMVC一般就需要直接返回视图,而现在新兴的前端技术vue在项目中为前后端分离的架构,前端框架负责处理数据和渲染页面,而后端 API 则负责提供数据即可,所以对返回视图的要求也就比较少了
### 回答1: 有什么区别? 控制器是一种模型,用于控制应用程序的行为。RestController是一种特殊的控制器,它只处理RESTful Web服务请求,而普通控制器可以处理多种不同的请求。RestController支持HTTP方法,如GET、POST、PUT和DELETE,而普通控制器不支持这些方法。 ### 回答2: @RestController和@ControllerSpring框架中的两个重要注解,用于定义处理HTTP请求的控制器。 @RestController是@Controller和@ResponseBody的组合注解,用于标记一个类是处理HTTP请求的控制器,并且返回的数据会被直接写入HTTP响应体中。一般用于构建RESTful API。这意味着@RestController中的方法会自动将返回的数据转换为JSON或XML等格式,并通过HTTP协议返回给客户端。 @Controller注解用于标记一个类是处理HTTP请求的控制器,但是它的方法不会将返回值直接写入HTTP响应体中,需要配合@ResponseBody注解来明确指定返回值要写入HTTP响应体中。常用于构建传统的Web应用程序。 两者区别主要在于返回值的处理方式,@RestController会自动将返回值转换为JSON等格式并写入HTTP响应,而@Controller需要配合@ResponseBody将返回值写入HTTP响应。在需要构建RESTful API和返回JSON等格式的项目中一般使用@RestController,而在传统的Web应用程序中一般使用@Controller。 总结:@RestController和@Controller都是处理HTTP请求的控制器。@RestController会自动将返回值转换为JSON等格式并写入HTTP响应,而@Controller需要配合@ResponseBody将返回值写入HTTP响应。 ### 回答3: @RestController和@ControllerSpring框架中用来处理HTTP请求的两个注解。 最主要的区别在于,@RestController是@Controller和@ResponseBody的组合,用于处理返回JSON或XML格式数据的请求,而@Controller则用于处理视图返回的请求。 @RestController注解告诉Spring这个控制器将返回数据,而不是视图。它可以将返回的数据直接转换为JSON、XML等格式,而不需要使用@ResponseBody注解。@RestController通常用于构建RESTful风格的服务接口,用于返回数据给客户端。 @Controller注解告诉Spring这个控制器将返回一个视图,而不是数据。它通常用于构建应用程序的页面导航逻辑,处理返回HTML格式的请求。可以使用在方法上使用@RequestMapping注解来指定视图的URL和请求方法。 综上所述,@RestController和@Controller都是用来处理HTTP请求的注解,用途略有不同。@RestController用于返回数据,主要用于构建RESTful风格的服务接口;而@Controller用于返回视图,主要用于构建应用程序的页面导航逻辑。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值