20_RESTful 十大规范

RESTful规范

一、什么是RESTful

  • REST与技术无关,代表的是一种软件架构风格,REST是Representational State Transfer的简称,中文翻译为“表征状态转移
  • REST从资源的角度类审视整个网络,它将分布在网络中某个节点的资源通过URL进行标识,客户端应用通过URL来获取资源的表征,获得这些表征致使这些应用转变状态
  • 所有的数据,不过是通过网络获取的还是操作(增删改查)的数据,都是资源,将一切数据视为资源是REST区别与其他架构风格的最本质属性
  • 对于REST这种面向资源的架构风格,有人提出一种全新的结构理念,即:面向资源架构(ROA:Resource Oriented Architecture)

二、十大规范

OK - [GET]:服务器成功返回用户请求的数据,该操作是幂等的(Idempotent)。
CREATED - [POST/PUT/PATCH]:用户新建或修改数据成功。
Accepted - [*]:表示一个请求已经进入后台排队(异步任务)
NO CONTENT - [DELETE]:用户删除数据成功。
INVALID REQUEST - [POST/PUT/PATCH]:用户发出的请求有错误,服务器没有进行新建或修改数据的操作,该操作是幂等的。
Unauthorized - [*]:表示用户没有权限(令牌、用户名、密码错误)。
Forbidden - [*] 表示用户得到授权(与401错误相对),但是访问是被禁止的。
NOT FOUND - [*]:用户发出的请求针对的是不存在的记录,服务器没有进行操作,该操作是幂等的。
Not Acceptable - [GET]:用户请求的格式不可得(比如用户请求JSON格式,但是只有XML格式)。
Gone -[GET]:用户请求的资源被永久删除,且不会再得到的。
Unprocesable entity - [POST/PUT/PATCH] 当创建一个对象时,发生一个验证错误。
INTERNAL SERVER ERROR - [*]:服务器发生错误,用户将无法判断发出的请求是否成功。

更多看这里:http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html
  • 错误处理,应返回错误信息,error当做key。
{
    'status':状态码,
    'error':错误信息,
}
  • 返回结果,针对不同操作,服务器向用户返回的结果应该符合以下规范。
GET /collection:返回资源对象的列表(数组)
GET /collection/resource:返回单个资源对象
POST /collection:返回新生成的资源对象
PUT /collection/resource:返回完整的资源对象
PATCH /collection/resource:返回完整的资源对象
DELETE /collection/resource:返回一个空文档
  • Hypermedia API,RESTful API最好做到Hypermedia,即返回结果中提供链接,连向其他API方法,使得用户不查文档,也知道下一步应该做什么。
{"link": {
  "url": "路由"
  "rel":   "collection https://www.example.com/zoos",
  "href":  "https://api.example.com/zoos",
  "title": "List of zoos",
  "type":  "application/vnd.yourformat+json"
}}

三、在django中简单实现

前台通过发送不同的请求,进入不同的函数属性
class Book(APIView):

    def get(self, request):
        book_list = models.Books.objects.all()
        return render(request, 'books.html', locals())

    def put(self, request, pk):
        name = request.data.get('name')
        price = request.data.get('price')
        date = request.data.get('date')
        models.Books.objects.filter(pk=pk).update(name=name, price=price, create_date=date)
        return JsonResponse({'status': 100, 'msg': '成功'})

    def post(self, request):
        name = request.data.get('name')
        price = request.data.get('price')
        date = request.data.get('date')
        if name and price and date:
            models.Books.objects.create(name=name, price=price, create_date=date)
            return JsonResponse({'status': 100, 'msg': '成功'})
        else:
            return JsonResponse({'status': 200, 'msg': '失败'})

    def delete(self, request, pk):
        models.Books.objects.filter(pk=pk).delete()
        return JsonResponse({'status': 100, 'msg': '成功'})

码云源码链接

安装djangorestframework模块
方式一:pip3 install djangorestframework

方式二:pycharm图形化界面安装

方式三:pycharm命令行下安装(装在当前工程所用的解释器下)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,134评论 19 139
  • 去年有段时间得空,就把谷歌GAE的API权威指南看了一遍,收获颇丰,特别是在自己几乎独立开发了公司的云数据中心之后...
    骑单车的勋爵阅读 20,962评论 0 41
  • RESTful规范 一. 什么是RESTful 一切皆资源RESTful : 面向资源架构(ROA:Resourc...
    墨颜丶阅读 3,424评论 0 0
  • 最近两年三番两次搬家,丢掉了一个很重要的U盘。里面保存着近十年来所有的照片,视频。后想到曾在360云盘留过备份,打...
    纠结的大饼阅读 1,153评论 1 1
  • 莫道桂林甲天下,明仕风景甲桂林。 群峰倒影山浮水,无水无山不入神。 广西大部地区是喀斯特山水,《花千骨》让明仕田园...
    思慕许姐阅读 3,265评论 0 1

友情链接更多精彩内容