响应HttpServietResponse
介绍
-
将@ResponseBody 加到Controller方法/类上
-
作用:将方法返回值直接响应,如果返回值是 实体对象/集合,将会自动转JSON格式响应
-
@RestController = @Controller + @ResponseBody;
一般响应
统一响应
-
在实际开发中一般不会用不同的类作为响应,因为不方便管理,一般会有一个类统一响应
-
一般会带状态码,和响应类型
public class Result{
//响应状态 如 1代表成功 0失败
private Integer status;
//提示信息,告诉前端我响应的是响应
private String msg;
//数据部分
private Object data;
//所有get/set方法 要确保data的对象的属性也有所有set/get方法
//返回的json 格式是根据getXXX(); XXX的名称来命名键名,本且转小写
}
@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会将这个字符串直接写入响应体。
-
-
示例:
@RequestMapping("/greeting") @ResponseBody public String greeting() { return "Hello, World!"; }
上述代码中,访问
/greeting
路径将直接返回字符串"Hello, World!"作为响应体。
统一响应结果
-
目的: 统一的响应格式有助于前后端分离的开发模式,使得前端开发者可以更容易地处理来自后端的数据。
-
组成部分:
-
code: 通常是一个整数,表示请求的处理结果。例如,
200
表示成功,404
表示未找到,500
表示服务器错误等。 -
msg: 是一个字符串,提供关于响应的额外信息。在成功时,可能是操作的描述;在失败时,提供错误信息。
-
data: 包含实际返回的数据。在成功的响应中,这里可能是请求的数据对象或数据集合。
-
-
优点:
-
标准化: 使得API的响应格式统一,简化客户端的处理逻辑。
-
易于调试: 通过状态码和消息,可以快速识别请求是否成功以及失败的原因。
-
扩展性: 方便添加额外的信息,如时间戳、分页信息等,而不影响现有逻辑。
-
-
示例:
{ "code": 200, "msg": "操作成功", "data": { // 实际的数据对象 } }
这个JSON对象是一个典型的统一响应结果示例,它清晰地表明了操作的状态和返回的数据。