(仅供个人参考)
HTTP请求方法的下限制:
//获取用户列表
@RequestMapping(value = "users",method = RequestMethod.GET)
@ResponseBody
public List<Emp> getUsers(){
List<Emp> list = new ArrayList();
list.add(new Emp(1L,"A"));
list.add(new Emp(2L,"B"));
list.add(new Emp(3L,"C"));
return list;
}
requestMapping的参数化:
@PathVariable路径参数映射:
//获取用户
@RequestMapping("users/{id}")
@ResponseBody
//@PathVariable():接收带路径参数
public Emp getUser(@PathVariable("id") Long id) {
System.out.println("id :" + id);
return new Emp(1L, "xxx");
}
requestMapping的继承:
开发中可以使用@RequestMapping的继承
@Controller
@RequestMapping("users")
public class EmpController {
//获取用户列表
@RequestMapping(method = RequestMethod.GET)
@ResponseBody
public List<Emp> getUsers() {
List<Emp> list = new ArrayList();
list.add(new Emp(1L, "A"));
list.add(new Emp(2L, "B"));
list.add(new Emp(3L, "C"));
return list;
}
//获取用户
@RequestMapping(value = "/{id}",method = RequestMethod.GET)
@ResponseBody
//@PathVariable():接收带路径参数
public Emp getUser(@PathVariable("id") Long id) {
System.out.println("id :" + id);
return new Emp(1L, "xxx");
}
//删除用户
@RequestMapping(value = "/{id}",method = RequestMethod.DELETE)
@ResponseBody
//@PathVariable():接收带路径参数
public void deletetUser(@PathVariable("id") Long id) {
System.out.println("删除成功...");
}
}
@RestController:
相当于@Controller所有的方法自动添加上@ResponseBody;
@RestController
@RequestMapping("users")
public class EmpController {
//获取用户列表
@GetMapping
public List<Emp> getUsers() {
List<Emp> list = new ArrayList();
list.add(new Emp(1L, "A"));
list.add(new Emp(2L, "B"));
list.add(new Emp(3L, "C"));
return list;
}
//获取用户
@GetMapping("/{id}")
public Emp getUser(@PathVariable("id") Long id) {
System.out.println("id :" + id);
return new Emp(1L, "xxx");
}
//删除用户
@DeleteMapping("/{id}")
public void deletetUser(@PathVariable("id") Long id) {
System.out.println("删除成功...");
}
}
postman body参数说明:
一:form-data
就是http请求中的multipart/form-data,它会将表单的数据处理为一条消息,以标签为单元,用分隔符分开。既可以上传键值对,也可以上传文件。当上传的字段是文件时,会有Content-Type来说明文件类型;content-disposition,用来说明字段的一些信息;
由于有boundary隔离,所以multipart/form-data既可以上传文件,也可以上传键值对,它采用了键值对的方式,所以可以上传多个文件。
二:x-www-form-urlencoded
application/x-www-from-urlencoded,会将表单内的数据转换为键值对,如:name=leyangjun&age =28&work=meituan
三:raw
可上传任意格式的文本,可以上传text、json、xml、html等各种文本类型,需要使用@RequestBody 接受
四:binary
等同于Content-Type:application/octet-stream,只可上传二进制数据,通常用来上传文件,由于没有键值,所以一次只能上传一个文件。
注意:
form-data与x-www-form-urlencoded不同之处在于(multipart/form-data:既可以上传文件等二进制数据,也可以上传表单键值对,只是最后会转化为一条信息; x-www-form-urlencoded:只能上传键值对,且键值对都是间隔分开。)
RequestMapping具体属性:
params:约束参数
//获取用户
@RequestMapping(value = "/{id}",method = RequestMethod.GET,params = "pwd=999")
public Emp getUser(@PathVariable("id") Long id) {
System.out.println("id :" + id);
return new Emp(1L, "xxx");
}
headers:放置请求头属性,限制请求头信息
//获取用户
@RequestMapping(value = "/{id}",method = RequestMethod.GET,headers = "Content-Type=application/json")
public Emp getUser(@PathVariable("id") Long id) {
System.out.println("id :" + id);
return new Emp(1L, "xxx");
}
produces: 生产
示例: produces="application/json"
表明该方法只生产json类型的数据, 换而言之, 就是该请求要求返回一个json类型的数据
produces="application/json" == headers="Accept=application/json"
consumes: 消费
示例: consumes="application/json"
表明该方法只消费json类型的数据, 换而言之, 前端要请求此方法,携带的数据必须是json类型的
consumes="application/json" == headers="contentType=application/json"