Springboot对于不同的请求进行响应
java">package com.wzb.ResponseExercise20240919;import com.wzb.ResponseExercise20240919.Result.Result;
import com.wzb.ResponseExercise20240919.pojo.User;
import jakarta.servlet.http.HttpServletRequest;
import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;import java.time.LocalDateTime;
import java.util.Arrays;
import java.util.List;// 添加RestController注解,表示此类中所有方法的返回值都作为浏览器的响应数据@RestController
public class ResponseExercise {// Controller方法中,已经设置了响应浏览器请求的数据// Controller方法中的return的结果,是通过@ResponseBody注解响应给浏览器的// @ResponseBody注解// 1.类型:方法注解,类注解;可以为类或者方法进行注解// 2.位置:书写在@Controller方法或者类上// 3.作用:将方法返回值直接响应给浏览器(如果方法返回值是实体对象/集合),那么将会转换为json格式后再响应给浏览器// 但是在一般的书写中,只是在类上添加了@RestController的注解,方法添加了@RequestMapping注解,并没有直接使用@RespondBody注解// 是因为@RestContorller是一个组合注解,是@Controller和@ResponseBody的组合,所以说不需要直接使用@RespondBody就可以响应浏览器// 可以理解为添加了@RestController注解就相当于添加了@ResponseBody注解// 类上有@RestController注解或者@ResponseBody注解时,表示当前类下所有的方法的返回值都作为浏览器的响应参数/* 无参数的请求 */@RequestMapping("/Hello")public Result function() {System.out.println("hello world");return Result.success("Hello World");}/* 请求普通参数 */@RequestMapping("/simpleParam")public Result simpleParam(String name) {System.out.println("I am " + name);return Result.success(("I am " + name));}/* 请求普通参数的复杂写法 */
// @RequestMapping("/simpleParam")
// public String simpleParam(HttpServletRequest request) {
// String name = request.getParameter("name");
// int age = Integer.parseInt(request.getParameter("age"));
// System.out.println(name + ": " + age);
// return (name + ": " + age);
// }/* 请求实体对象 *//* 若响应的是实体对象,那么前端将会以json格式展示出来 */@RequestMapping("/simplePojo")public Result simplePojo (User user) {System.out.println(user);return Result.success(user);}/* 请求数组 */@RequestMapping("/simpleArray")public Result simpleArray(String[] hobby) {System.out.println(Arrays.toString(hobby));return Result.success(hobby);}/* 请求集合 *//* 因为默认是响应数组,所以说想要响应集合需要用@RequestParam注解 */@RequestMapping("/simpleList")public Result simpleList(@RequestParam List<String> hobby) {System.out.println(hobby);return Result.success(hobby);}/* 请求时间日期参数 */@RequestMapping("/updateTime")public Result dateParam(@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") LocalDateTime updateTime) {System.out.println("现在的时间是: " + updateTime);return Result.success(updateTime);}/* 请求json参数 */@RequestMapping("/jsonParam")public Result jsonParam(@RequestBody User user) {System.out.println(user);return Result.success(user);}
}
User类
java">package com.wzb.ResponseExercise20240919.pojo;public class User {private String name;private int age;private Address address;public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public Address getAddress() {return address;}public void setAddress(Address address) {this.address = address;}@Overridepublic String toString() {return "User{" +"name='" + name + '\'' +", age=" + age +", address=" + address +'}';}
}
Address类
java">package com.wzb.ResponseExercise20240919.pojo;public class Address {private String province;private String city;public String getProvince() {return province;}public void setProvince(String province) {this.province = province;}public String getCity() {return city;}public void setCity(String city) {this.city = city;}@Overridepublic String toString() {return "Address{" +"province='" + province + '\'' +", city='" + city + '\'' +'}';}
}
统一返回结果Result
java">package com.wzb.ResponseExercise20240919.Result;public class
Result {private Integer code; // 响应状态码:1代表成功;0代表失败private String message; // 状态码信息 描述的字符串private Object data; // 返回的数据,因为是返回的数据千奇百怪,所以说用顶级父类Object当作数据的类型public Result() {}public Result(Integer code, String message, Object data) {this.code = code;this.message = message;this.data = data;}public Integer getCode() {return code;}public void setCode(Integer code) {this.code = code;}public String getMessage() {return message;}public void setMessage(String message) {this.message = message;}public Object getData() {return data;}public void setData(Object data) {this.data = data;}// 为了提高效率,为成功响应和失败响应分别封装静态方法// 成功响应(不需要给前端返回数据)public static Result success() {return new Result(1, "success", null);}// 成功响应(需要给前端返回数据)public static Result success(Object data) {return new Result(1, "success", data);}// 失败响应public static Result error(String message) {return new Result(0, "Fail", null);}
}
统一返回测试
java">package com.wzb.ResponseExercise20240919;import com.wzb.ResponseExercise20240919.Result.Result;
import com.wzb.ResponseExercise20240919.pojo.User;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class ResponseTogetherExercise {/* 响应的值多种多样,没有规范;不便于前后端分离开发:前端若拿到响应的数据,没有统一的规范,那么需要对不同的数据进行不同的解析,成本高、效率低、维护困难 *//* 所以说一般在开发中,定义一个统一的返回结果,所有请求都返回这个类型的结果,便于开发 *//* 这个统一的返回结果应该包含:1.响应状态码:当前的请求的成功还剩失败2.状态码信息:给页面的提示信息3.返回的数据:给前端响应的数据(字符串、对象、集合;所以说要用Object定义数据类型)*//* 有了统一的返回结果Result之后,就可以对Controller进行改造 */@RequestMapping("/simplePojoTogether")public Result simplePojo(User user) {System.out.println(user);/* 能够走到这一步,那么说明成功响应了 */return Result.success(user);}}