SpingBoot快速入门下

响应HttpServietResponse

介绍
  • 将**@ResponseBody** 加到Controller方法/类上

  • **作用:**将方法返回值直接响应,如果返回值是 实体对象/集合,将会自动转JSON格式响应

  • @RestController = @Controller + @ResponseBody;

一般响应
统一响应
  • 在实际开发中一般不会用不同的类作为响应,因为不方便管理,一般会有一个类统一响应

  • 一般会带状态码,和响应类型

java 复制代码
public class Result{
    //响应状态 如 1代表成功 0失败
    private Integer status;
    //提示信息,告诉前端我响应的是响应
    private String msg;
    //数据部分
    private Object data;
    //所有get/set方法  要确保data的对象的属性也有所有set/get方法
    //返回的json 格式是根据getXXX(); XXX的名称来命名键名,本且转小写
}
java 复制代码
@RestController
public class TestController{ 
    //一般响应
   @RequestMapping("/getData")
    public _User getData(){
        System.out.println("getDataRequest");
        _User user = new _User();
        user.test = "test_001";
        user.age= 500;
        user.addre = new Address();
        user.addre.province = "A";
        user.addre.city = "cityb_A_001";
        return user;
    }
    //统一响应
    @RequestMapping("/getResult")
    public Result getResult(){
        System.out.println("getResult");
        _User user = new _User();
        user.test = "test_001";
        user.age= 500;
        user.addre = new Address();
        user.addre.province = "A";
        user.addre.city = "cityb_A_001";
        Result res = new Result();
        res.status = 1;             //表示成功
        res.msg = "Class _User";     //表示数据是_User 类
        res.data = user;
        return res;
    }
}
总结

@ResponseBody 注解

  • 定义 : @ResponseBody是Spring MVC框架中的一个注解,它的作用是指示方法的返回值应该直接作为响应体返回给客户端,而不是返回一个视图(View)。

  • 使用场景:

    • 当你想要返回JSON、XML等数据格式,而不是跳转到一个页面。

    • 当你正在构建RESTful API,需要直接返回数据而不是视图。

  • 工作原理:

    • @ResponseBody注解的方法,其返回值将被Spring MVC的HttpMessageConverter转换成客户端请求的格式(如JSON)。

    • 如果方法返回的是String类型,Spring MVC会将这个字符串直接写入响应体。

  • 示例:

    java 复制代码
    @RequestMapping("/greeting")
    @ResponseBody
    public String greeting() {
        return "Hello, World!";
    }

    上述代码中,访问

    复制代码
    /greeting

    路径将直接返回字符串"Hello, World!"作为响应体。

统一响应结果

  • 目的: 统一的响应格式有助于前后端分离的开发模式,使得前端开发者可以更容易地处理来自后端的数据。

  • 组成部分:

    • code : 通常是一个整数,表示请求的处理结果。例如,200表示成功,404表示未找到,500表示服务器错误等。

    • msg: 是一个字符串,提供关于响应的额外信息。在成功时,可能是操作的描述;在失败时,提供错误信息。

    • data: 包含实际返回的数据。在成功的响应中,这里可能是请求的数据对象或数据集合。

  • 优点:

    • 标准化: 使得API的响应格式统一,简化客户端的处理逻辑。

    • 易于调试: 通过状态码和消息,可以快速识别请求是否成功以及失败的原因。

    • 扩展性: 方便添加额外的信息,如时间戳、分页信息等,而不影响现有逻辑。

  • 示例:

    java 复制代码
    {
      "code": 200,
      "msg": "操作成功",
      "data": {
        // 实际的数据对象
      }
    }

    这个JSON对象是一个典型的统一响应结果示例,它清晰地表明了操作的状态和返回的数据。

相关推荐
用户908324602731 小时前
Spring AI 1.1.2 + Neo4j:用知识图谱增强 RAG 检索(上篇:图谱构建)
java·spring boot
用户83071968408221 小时前
Spring Boot 集成 RabbitMQ :8 个最佳实践,杜绝消息丢失与队列阻塞
spring boot·后端·rabbitmq
Java水解1 天前
Spring Boot 视图层与模板引擎
spring boot·后端
Java水解1 天前
一文搞懂 Spring Boot 默认数据库连接池 HikariCP
spring boot·后端
洋洋技术笔记1 天前
Spring Boot Web MVC配置详解
spring boot·后端
初次攀爬者2 天前
Kafka 基础介绍
spring boot·kafka·消息队列
用户8307196840822 天前
spring ai alibaba + nacos +mcp 实现mcp服务负载均衡调用实战
spring boot·spring·mcp
Java水解2 天前
SpringBoot3全栈开发实战:从入门到精通的完整指南
spring boot·后端
初次攀爬者3 天前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺3 天前
搞懂@Autowired 与@Resuorce
java·spring boot·后端