Rest风格开发Api

6/21/2022 javaRESTful

# Rest风格

# 简介

REST(Representational State Transfer),表现形式状态转换

# 传统风格资源描述形式

http://localhost/user/getById?id=1
http://localhost/user/saveUser

# REST风格描述形式

http://localhost/user/1
http://localhost/user

# REST风格优点

  • 隐藏资源的访问行为,无法通过地址得知对资源是何种操作
  • 书写简化

# 按照REST风格访问资源时使用行为动作区分对资源进行了何种操作

  • http://localhost/users 查询全部用户信息 GET(查询)
  • http://localhost/users/1 查询指定用户信息 GET(查询)
  • http://localhost/users 添加用户信息 POST(新增/保存)
  • http://localhost/users 修改用户信息 PUT(修改/更新)
  • http://localhost/users/1 删除用户信息 DELETE(删除)

# 根据REST风格对资源进行访问成为RESTful

​ 注意事项:

上述行为是约定方式,约定不是规范,可以打破,所以称REST风格,而不是REST规范

描述模块的名称通常使用复数,也就是加s的格式描述,表示此类资源,而非单个资源,例如:users、books、accounts...

# 入门案例

Step

  1. 设定http请求动作
    //设置当前请求方法为POST,表示REST风格中的添加操作
    @RequestMapping(value = "/users",method = RequestMethod.POST)
    @ResponseBody
    public String save(){
        System.out.println("user save...");
        return "{'module':'user save'}";
    }

    //设置当前请求方法为PUT,表示REST风格中的修改操作
    @RequestMapping(value = "/users",method = RequestMethod.PUT)
    @ResponseBody
    public String update(@RequestBody User user){
        System.out.println("user update..."+user);
        return "{'module':'user update'}";
    }

    //设置当前请求方法为GET,表示REST风格中的查询操作
    //@PathVariable注解用于设置路径变量(路径参数),要求路径上设置对应的占位符,并且占位符名称与方法形参名称相同
    @RequestMapping(value = "/users/{id}" ,method = RequestMethod.GET)
    @ResponseBody
    public String getById(@PathVariable Integer id){
        System.out.println("user getById..."+id);
        return "{'module':'user getById'}";
    }
  1. 设定请求参数(路径变量)
    //设置当前请求方法为DELETE,表示REST风格中的删除操作
    //@PathVariable注解用于设置路径变量(路径参数),要求路径上设置对应的占位符,并且占位符名称与方法形参名称相同
    @RequestMapping(value = "/users/{id}",method = RequestMethod.DELETE)
    @ResponseBody
    public String delete(@PathVariable Integer id){
        System.out.println("user delete..." + id);
        return "{'module':'user delete'}";
    }

# 接收参数方式选择

@RequestBody @RequestParam @PathVariable

  • 区别
    • @RequestParam 用于接收url地址传参或表单传参
    • @RequestBody 用于接收json数据
    • @PathVariable 用于接收路径参数,使用{参数名称}描述路径参数
  • 应用
    • 后期开发中,发送请求参数超过1个时,以json格式为主,@RequestBody应用较广
    • 如果发送非json格式数据,选用@RequestParam接收请求参数
    • 采用RESTful进行开发,当参数数量较少时,例如1个,可以采用@PathVariable接收请求路径变量,通常用于传递id值

# RESTful快速开发1

  • 名称: @RestController

  • 类型: 类注解

  • 位置: 基于SpringMVC的RESTful开发控制器类定义上方

  • 作用: 设置当前控制器类为RESTful风格,等同于@Controller与@ResponseBody两个注解组合功能

  • 范例

    @RestController
    public class BookController {
    	
    }
    
  • 名称: @GetMapping @PostMapping @PutMapping @DeleteMapping

  • 类型: 方法注解

  • 位置: 基于SpringMVC的RESTful开发控制器方法定义上方

  • 作用: 设置当前控制器方法请求访问路径与请求动作,每种对应一个请求动作,例如@GetMapping对应GET请求

  • 范例:

        @GetMapping("/{id}")    //使用@GetMapping简化GET请求方法对应的映射配置
        public String getById(@PathVariable Integer id){
            System.out.println("book getById..."+id);
            return "{'module':'book getById'}";
        }
    
  • 属性:

    • value (默认): 请求访问路径
Last Updated: Monday, August 22, 2022 1:33 PM
斑驳陆离之林,恍若隔世
Robyn