【Spring MVC】_SpringMVC项目返回数据

目录

[1. 注解使用示例](#1. 注解使用示例)

[1.1 使用@Controller注解](#1.1 使用@Controller注解)

[1.2 使用@RestController注解](#1.2 使用@RestController注解)

[1.3 使用@Controller与@ResponseBody注解](#1.3 使用@Controller与@ResponseBody注解)

[2. 关于ResponseBody注解](#2. 关于ResponseBody注解)


前文已经介绍过使用@Controller注解向前端返回一个HTML页面,接下来将介绍向前端返回数据。

关于@Controller和@RestController的区别与联系,本专栏已有介绍,如需要请查看下文:

【Spring MVC】_SpringMVC项目返回静态页面_mvc 返回当前页面-CSDN博客https://blog.csdn.net/m0_63299495/article/details/138230689简单概括:返回视图使用@Controller,

返回数据使用@RestController 或 @Controller与@ResponseBody;

在本专栏介绍SpringMVC项目传参问题时,其实一直在使用@RestController注解向前端返回数据,本篇仍做简单示例:

1. 注解使用示例

1.1 使用@Controller注解

.java文件内容如下:

java 复制代码
package com.example.demo.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RequestMapping("/return")
@Controller
public class ReturnController {
    @RequestMapping("/returnData")
    public String returnData(){
        return "Return as Data.";
    }
}

运行启动类,测试结果如下:

由于使用了@Controller注解,则返回视图,

故而在static路径下查找"Return as Data"的视图,查询未果故而报404错误;

1.2 使用@RestController注解

.java文件内容如下:

java 复制代码
package com.example.demo.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RequestMapping("/return")
@RestController
public class ReturnController {
    @RequestMapping("/returnData")
    public String returnData(){
        return "Return as Data.";
    }
}

运行启动类,测试结果如下:

1.3 使用@Controller与@ResponseBody注解

.java文件内容如下:

java 复制代码
package com.example.demo.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

@RequestMapping("/return")
@Controller
@ResponseBody
public class ReturnController {
    @RequestMapping("/returnData")
    public String returnData(){
        return "Return as Data.";
    }
}

运行启动类,测试结果如下:

2. 关于ResponseBody注解

查看源码:

@ResponseBody注解就可以修饰类,也可以用于修饰方法

修饰类的时候表示:这个类下的所有方法返回的均为数据;

修饰方法时:表示该方法返回的是数据;

如果一个类中所有的方法都需要返回数据,就可以把该注解加在类上;

如果一个类中既有方法返回数据,又有方法返回页面,则在返回数据的方法上加该注解即可;

相关推荐
1104.北光c°4 分钟前
滑动窗口HotKey探测机制:让你的缓存TTL更智能
java·开发语言·笔记·程序人生·算法·滑动窗口·hotkey
云原生指北3 小时前
GitHub Copilot SDK 入门:五分钟构建你的第一个 AI Agent
java
Leinwin7 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
薛定谔的悦7 小时前
MQTT通信协议业务层实现的完整开发流程
java·后端·mqtt·struts
enjoy嚣士8 小时前
springboot之Exel工具类
java·spring boot·后端·easyexcel·excel工具类
罗超驿8 小时前
独立实现双向链表_LinkedList
java·数据结构·链表·linkedlist
盐水冰9 小时前
【烘焙坊项目】后端搭建(12) - 订单状态定时处理,来单提醒和顾客催单
java·后端·学习
凸头9 小时前
CompletableFuture 与 Future 对比与实战示例
java·开发语言
wuqingshun3141599 小时前
线程安全需要保证几个基本特征
java·开发语言·jvm
努力也学不会java9 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试