SpringMVC对restful的支持

(仅供个人参考)
HTTP请求方法的下限制:

//获取用户列表
    @RequestMapping(value = "users",method = RequestMethod.GET)
    @ResponseBody
    public List getUsers(){
        List list = new ArrayList();
        list.add(new Emp(1L,"A"));
        list.add(new Emp(2L,"B"));
        list.add(new Emp(3L,"C"));
        return list;
    }
Snipaste_2018-10-16_19-42-43.jpg
image.png

requestMapping的参数化:
@PathVariable路径参数映射:

//获取用户
    @RequestMapping("users/{id}")
    @ResponseBody
    //@PathVariable():接收带路径参数
    public Emp getUser(@PathVariable("id") Long id) {
        System.out.println("id :" + id);
        return new Emp(1L, "xxx");
    }
image.png

image.png

requestMapping的继承:
开发中可以使用@RequestMapping的继承

@Controller
@RequestMapping("users")
public class EmpController {

    //获取用户列表
    @RequestMapping(method = RequestMethod.GET)
    @ResponseBody
    public List getUsers() {
        List 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 getUsers() {
        List 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");
    }
image.png

image.png

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");
    }
image.png

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"

你可能感兴趣的:(SpringMVC对restful的支持)