简介

REST:英文representational state transfer直译为表现层状态转移,或者表述性状态转移;Rest是web服务的一种架构风格,一种设计风格,是一种思想;同时Rest不是针对某一种编程语言的。

以webService为例通俗解释。

非Rest设计,以往我们都会这么写:

http://localhost:8080/admin/getUser (查询用户)

http://localhost:8080/admin/addUser (新增用户)

http://localhost:8080/admin/updateUser (更新用户)

http://localhost:8080/admin/deleteUser (删除用户)

总结:以不同的URL(主要为使用动词)进行不同的操作。

Rest架构:

GET http://localhost:8080/admin/user (查询用户)

POST http://localhost:8080/admin/user (新增用户)

PUT http://localhost:8080/admin/user (更新用户)

DELETE http://localhost:8080/admin/user (删除用户)

总结:URL只指定资源,以HTTP方法动词进行不同的操作。用HTTP STATUS/CODE定义操作结果。

Restful:遵守了rest风格的web服务便可称为Restful。

为什么需要Restful?

URL具有很强可读性的,具有自描述性

规范化请求过程和返回结果

资源描述与视图的松耦合

可提供OpenAPI,便于第三方系统集成,提高互操作性

提供无状态的服务接口,降低复杂度,可提高应用的水平扩展性

/版本号/资源路径

/v1/tags/{tag_id}

/v1/users?[&keyword=xxx][&enable=1][&offset=0][&limit=20]

1、版本号

命名版本号可以解决版本不兼容问题,在设计 RESTful API 的一种实用的做法是使用版本号。一般情况下,我们会在 url 中保留旧版本号,并同时兼容多个版本

【GET】  /v1/users/{user_id}  // 版本 v1 的查询用户列表的 API 接口

【GET】  /v2/users/{user_id}  // 版本 v2 的查询用户列表的 API 接口

2、资源路径

URI 不能包含动词,只能是名词(命名名词的时候,要使用小写、数字及下划线来区分多个单词)。

资源的路径应该从根到子依次如下:

/{resources}/{resource_id}/{sub_resources}/{sub_resource_id}/{sub_resource_property}

【POST】  /v1/users/{user_id}/roles/{role_id} // 添加用户的角色

有的时候,当一个资源变化难以使用标准的 RESTful API 来命名,可以考虑使用一些特殊的 actions 命名。

/{resources}/{resource_id}/actions/{action}

【PUT】  /v1/users/{user_id}/password/actions/modify // 密码修改

3、请求方式

【GET】          /users                # 查询用户信息列表

【GET】          /users/1001           # 查看某个用户信息

【POST】         /users                # 新建用户信息

【PUT】          /users/1001           # 更新用户信息(全部字段)

【PATCH】        /users/1001           # 更新用户信息(部分字段)

【DELETE】       /users/1001           # 删除用户信息

【PATCH】一般不用,用【PUT】

4、查询参数

RESTful API 接口应该提供参数,过滤返回结果。

【GET】  /{version}/{resources}/{resource_id}?offset=0&limit=20

5、响应参数

JSON格式(code、data、msg)

6、状态码

使用适合的状态码很重要,而不应该全部都返回状态码 200

状态码,可根据以下标准按照项目扩展自身状态码:

200~299段 表示操作成功:

200 操作成功,正常返回

201 操作成功,已经正在处理该请求

300~399段 表示参数方面的异常

300 参数类型错误

301 参数格式错误

302 参数超出正常取值范围

303 token过期

304 token无效

400~499段 表示请求地址方面的异常:

400 找不到地址

500~599段 表示内部代码异常:

500 服务器代码异常

7、完整事例

UserController.java@RestController(/v1)
@API(tag=”用户相关接口”)public class UserController {@Autowiredprivate UserJPARepository userJPARepository;/*** 查询用户列表* @return*/@GetMapping(value = "/user")public List<User> findUserList(){return userJPARepository.findAll();}/*** 根据Id查询一个用户* @param id* @return*/@GetMapping(value = "/user/query/{id}")public User findUserOne(@PathVariable("id") Integer id){return userJPARepository.findOne(id);}/*** 添加用户* @param name* @param age* @param country* @return*/@PostMapping(value = "/user")public User addUser(@RequestParam("name") String name, @RequestParam("age") int age,@RequestParam("country") String country){User user = new User();user.setName(name);user.setAge(age);user.setCountry(country);return userJPARepository.save(user);}/*** 删除用户* @param id  用户编号* @return*/@DeleteMapping(value = "/user/{id}")public  List<User> deleteUser(@PathVariable("id") Integer id){userJPARepository.delete(id);return userJPARepository.findAll();}/*** 更新用户* @param id* @param name* @param age* @param country* @return*/@PutMapping(value = "/user/{id}")public User updateUser(@PathVariable("id") Integer id, @RequestParam("name") String name,@RequestParam("age") int age, @RequestParam("country") String country){User user = userJPARepository.findById(id);user.setName(name);user.setAge(age);user.setCountry(country);return userJPARepository.save(user);}/*** 根据国家查询用户* @param country* @return*/@GetMapping(value = "/user/{country}")public List<User> findByCountry(@PathVariable("country") String country){return userJPARepository.findByCountry(country);}
}

RESTFul接口规范相关推荐

  1. Python接口自动化测试工具(Pytest+Allure+jsonpath+xlrd+excel、支持Restful接口规范)

    功能 1.实现:get/post请求(上传文件)::理论上其他delete/put等请求也实现了,支持restful接口规范 2.发送邮件 3.生成allure测试报告 4.压缩测试报告文件 5.数据 ...

  2. RESTful接口规范(学习笔记)

    1.URI 在了解RESTful接口规范之前,我们先来了解一下什么是URI. 1.URI 它是一种通一的资源标志符,大致的意思就是在web上的每一个可用的资源,例如 HTML.图片.程序等都有一个UR ...

  3. RESTful接口规范之GET/POST/PUT/DELETE

    REST 是Representational State Transfer的缩写,翻译是"表现层状态转化". 面向资源是REST最明显的特征,对于同一个资源的一组不同的操作.资源是 ...

  4. 关于RESTful一些注意事项,接口开发规范

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 最近在研究restful,公司开发要使用,所以自己就去网上找了好些资料,并整理了一套公司开发的接口规 ...

  5. 接口规范-API接口

    接口规范 一.Web API接口 1.1 什么是接口 ​ 同通过网络,规定前后台信息交互规则的url连接,是前后台信息交互的媒介. 1.2 接口的组成 ​ 1.url; ​ 2.请求方式:get.po ...

  6. 【自动化测试】接口测试之RESTful接口

    文章目录 1)REST(Representational State Transfer) 1.表现层(Representation) 资源(Resources) 2.状态转化(State Transf ...

  7. RESTful的正确姿势

    RESTfull定义 很多人都有这样的疑问: 什么是RESTful API/RESTful接口? RESTful接口规范是什么样子的? 下面是摘抄自百度百科词条RESTful. REST(英文:Rep ...

  8. 使用 ThinkJS + Vue.js 开发博客系统

    编者注:ThinkJS 作为一款 Node.js 高性能企业级 Web 框架,收到了越来越多的用户的喜爱.今天我们请来了 ThinkJS 用户 @lscho 同学为我们分享他基于 ThinkJS 开发 ...

  9. 微服务落地,我们在考虑什么?

    点击蓝色"程序猿DD"关注我哟 加个"星标",不忘签到哦 来源:博云技术社区 导读 微服务已经成为过去几年软件架构设计的"事实标准",大多数 ...

最新文章

  1. java methode_Java Method.getTypeParameters方法代码示例
  2. apache安装_Ubuntu20.04安装Sql+apache+php
  3. Lua和C++交互总结(很详细)
  4. 已知x=python是一种非常好的编程语言-为什么用Python,高级的Python是一种高级编程语言...
  5. 109. Leetcode 309. 最佳买卖股票时机含冷冻期 (动态规划-股票交易)
  6. 洛谷1006 传纸条
  7. bc8android汽车中控屛功能有哪些,丰田酷路泽中控台的8大功能 你们知道都是干什么用的?...
  8. Shiro的架构介绍
  9. PNG免扣素材,快速提升你的画面设计感!
  10. 如何解决JDK的安装路径中有空格的情况
  11. 基于RK3399Pro的BH1750驱动开发
  12. 【软件构造】过程与配置管理
  13. Python计算中国GDP在那一年超越美国GDP(假设)
  14. 第25章 串行FLASH文件系统FatFs
  15. 撰写测试用例----二维码支付
  16. wifi底层学习之路:四,iw指令剖析
  17. 通过浏览器导出网站证书
  18. 小米扫地机器人 虚拟墙_扫地机器人虚拟墙是什么东西?
  19. 如何利用Simulink来设计一个AEB的算法,并通过SCANeR仿真来测试?
  20. HTML+CSS制作知乎登录页面

热门文章

  1. java读取xls表格(提供免费下载jar包)
  2. 7-10 拯救007 (25 分)
  3. len在python_len(x) 击败 x.len(),从内置函数看 Python 的设计思想
  4. VC++的C运行库源代码位置
  5. Fireworks(whole page)
  6. No cache or cacheManager properties have been set. Authorization cache cannot be obtained.
  7. 血氧饱和度血氧仪方案
  8. PHP学习笔记——文件上传
  9. 霍尼韦尔服务器 型号,霍尼韦尔honeywell楼宇自控产品型号汇总表(一)
  10. 常用软件的包名和类名