@Controller和@RestController的区别?

知识点:@RestController注解相当于@ResponseBody + @Controller合在一起的作用。

1) 如果只是使用@RestController注解Controller,则Controller中的方法无法返回jsp页面,或者html,配置的视图解析器 InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容。

2) 如果需要返回到指定页面,则需要用 @Controller配合视图解析器InternalResourceViewResolver才行。
如果需要返回JSON,XML或自定义mediaType内容到页面,则需要在对应的方法上加上@ResponseBody注解。

例如:

1.使用@Controller 注解,在对应的方法上,视图解析器可以解析return 的jsp,html页面,并且跳转到相应页面
若返回json等内容到页面,则需要加@ResponseBody注解.

@CrossOrigin
@Controller
public class FileUploadController {

//跳转到上传文件的页面
@RequestMapping(value="/gouploadimg", method = RequestMethod.GET)
public String goUploadImg() {
//跳转到 templates 目录下的 uploadimg.html
return "uploadimg";
}

//处理文件上传
@RequestMapping(value="/testuploadimg", method = RequestMethod.POST)
public @ResponseBody String uploadImg(@RequestParam("file") MultipartFile file,
HttpServletRequest request) {
System.out.println("调用文件上传方法");
String contentType = file.getContentType();
String fileName = file.getOriginalFilename();

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

@CrossOrigin
@RestController /* @Controller + @ResponseBody*/
public class HospitalController {

    //注入Service服务对象
    @Autowired
    private HospitalService hospitalService;

    /**
     * 查询所有医院信息(未分页)
     */

    @RequestMapping(value = "findAllHospital",method = RequestMethod.GET)
    public  List<Hospital> findAllHospital(){
        List<Hospital> hospitalList= hospitalService.findAllHospital();
        return hospitalList;
    }
### 控制器注解的核心区别 在 Spring 框架中,`@Controller` `@RestController` 是用于处理 HTTP 请求的两个核心注解,但它们的应用场景行为存在显著差异。 `@Controller` 注解用于标记一个类为控制器组件,其方法返回值通常是一个视图名称。Spring MVC 会通过视图解析器将该名称解析为实际的视图资源(如 HTML 页面),并将模型数据填充到视图中以呈现给客户端[^1]。这种类型的控制器适合传统的服务器端渲染模式,例如返回 `.html` 文件作为响应内容。 ```java @Controller public class HomeController { @GetMapping("/") public String home() { return "index"; // 返回视图名称,由视图解析器解析 } } ``` 而 `@RestController` 则结合了 `@Controller` `@ResponseBody` 的功能。它表示该类中的所有方法都会直接将返回值序列化为 HTTP 响应体,而不是经过视图解析器处理。这意味着返回的数据通常是 JSON 或 XML 格式,适用于构建 RESTful API 接口,特别适合前后端分离架构中后端仅提供数据服务的情况[^2]。 ```java @RestController public class ApiController { @GetMapping("/data") public Map<String, Object> getData() { Map<String, Object> response = new HashMap<>(); response.put("message", "Hello, World!"); return response; // 返回值自动转换为 JSON } } ``` 若开发者尝试在使用 `@RestController` 的方法中返回视图名称,将会导致错误,因为框架不会进行视图解析操作[^3]。因此,在不确定是否需要返回页面的情况下,建议优先使用 `@Controller`,并在需要返回数据时手动添加 `@ResponseBody` 注解,以实现灵活的响应类型切换[^4]。 --- ### 使用场景对比 | 场景 | 推荐注解 | 说明 | |------|----------|------| | 返回 HTML 页面(如 Thymeleaf、JSP) | `@Controller` | 配合视图解析器使用,适合传统 MVC 架构 | | 提供 JSON/XML 数据接口 | `@RestController` | 默认返回数据格式,适用于 RESTful API | | 同一控制器中混合返回页面数据 | `@Controller` + `@ResponseBody` | 灵活控制方法返回类型 | --- ### 注意事项 - 在使用 `@RestController` 时,不应返回视图名称字符串,否则会导致视图解析失败。 - 若项目中包含模板引擎(如 Thymeleaf),确保依赖已正确引入,并且视图文件路径与控制器返回的视图名称匹配。 - 不推荐随意混用 `@Controller` `@ResponseBody`,除非确实需要在同一控制器中支持多种响应类型。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值