RESTFUL规范建议

Posted ruanshuxin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了RESTFUL规范建议相关的知识,希望对你有一定的参考价值。

RESTful概述
RESTful是目前最流行的一种互联网软件架构,是程序和程序之间进行数据交互需要遵循的规范。它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用。

REST是Representational State Transfer的缩写,是Roy Thomas Fielding在他2000年的博士论文中提出的。其提出的设计概念和准则为:

  1. 网络上的所有事物都可以抽象为资源

  2. 每个资源都应该有唯一的标识(identifier),对资源的操作不会改变标识

  3. 所有的操作都是无状态的

  4. 使用标准方法(GET、POST、PUT、PATCH、DELETE)操作资源

规范建议

    1. https代替http,保证数据传输时安全。
    2. 在url中一般要体现api标识,这样看到url就知道他是一个api。
        http://www.baidu.com/api/....(建议,因为他不会存在跨域的问题)
        http://api.baidu.com/....
        假设:
            前段:https://www.baidu.com/home
            后端:https://www.baidu.com/api/
    3. 在接口中要体现版本
        http://www.baidu.com/api/v1....
        注意:版本还可以放在请求头中
            http://www.baidu.com/api/
            accept: ...
            
    4. restful也称为面向资源编程,视网络上的一切都是资源,对资源可以进行操作,所以一般资源都用名词。
        http://www.baidu.com/api/user/
        
    5. 如果要加入一些筛选条件,可以添加在url中    
        http://www.baidu.com/api/user/?page=1&type=9

    6. 根据method不同做不同操作。
            get、post、put、patch、delete
    7. 返回给用户状态码
        - 200,成功
        - 300,301永久 /302临时
        - 400,403拒绝 /404找不到
        - 500,服务端代码错误
        
        自定制状态码:
                def get(self,request,*args,**kwargs):
                    result = {'code':1000,'data':None,'error':None}
                    try:
                        val = int('你好')
                    except Exception as e:
                        result['code'] = 10001
                        result['error'] = '数据转换错误'
                    return Response(result)
        
    8. 返回值
        GET http://www.baidu.com/api/user/
            [
                {'id':1,'name':'rsx','age':19},
                {'id':1,'name':'rsx','age':19},
            ]
        POST http://www.baidu.com/api/user/
            {'id':1,'name':'rsx','age':43}
            
        GET http://www.baidu.com/api/user/2/
            {'id':2,'name':'rsx','age':43}
            
        PUT http://www.baidu.com/api/user/2/
            {'id':2,'name':'rsx','age':43}
        
        PATCH https//www.baidu.com/api/user/2/
            {'id':2,'name':'rsx','age':43}
            
        DELETE https//www.baidu.com/api/user/2/
            空
    9. 操作异常时,要返回错误信息
    
        {
            error: "Invalid API key"
        }
    10. 对于下一个请求要返回一些接口:Hypermedia AP
        {
            'id':2,
            'name':'rsx',
            'age':43,
            'depart': "http://www.baidu.com/api/user/30/"
        }

以上是关于RESTFUL规范建议的主要内容,如果未能解决你的问题,请参考以下文章

Python接口自动化测试工具(Pytest+Allure+jsonpath+xlrd+excel支持Restful接口规范)建议收藏

无规矩不成方圆,聊一聊 Spring Boot 中 RESTful 接口设计规范

RestFul架构

php开发规范

restful接口设计规范总结

restful 架构风格的curd(增删改查)