美文网首页
20_RESTful 十大规范

20_RESTful 十大规范

作者: knot98 | 来源:发表于2018-12-10 20:11 被阅读0次

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命令行下安装(装在当前工程所用的解释器下)

相关文章

  • 20_RESTful 十大规范

    RESTful规范 一、什么是RESTful REST与技术无关,代表的是一种软件架构风格,REST是Repres...

  • 演讲与口才

    科学发声(腹式呼吸法) 规范吐字 TED演讲十大黄金法则: 不要忽悠 伟大梦想 好奇心和热情 故事 积极回应 不夸...

  • 2020-12-20

    大名县曙光小学十大文化品牌(图说之五) ——书法文化 “爱祖国、爱母语,说普通话,写规范字”。这是写在我们学校...

  • 排名公布:重庆十大肛肠医院排名

    重庆十大肛肠医院排名?重庆东大肛肠医院严格执行物价局相关收费标准,有着规范化的收费流程,始终坚持费用公开化、...

  • POS应用规范十大问题

    1.代码中如何修改每个域的格式 修改定义ISO6583包的结构体的内容 2.不同数据格式之间的区别")2.不同数据...

  • 《90%的玄机》

    年头岁尾,在医院,十大安全目标在每个医务人员的心中更加闪亮起来,而且耳熟能详,朗朗上口。 在临床护理中制度规范10...

  • 武当剑的美术规范

    动作规范 模型规范 贴图规范 场景规范 特效规范 UI贴图规范

  • 滴滴C2C模式隐忧暴露,神州专车却仍无力逆风翻盘?

    5月22日,中国消费者协会披露了目前网约车存在的十大乱象,并呼吁保护消费者权益,规范行业发展。从监管、审核、保护等...

  • 前端开发规范

    前端开发规范 规范目的 命名规范 结构化规范 注释规范 编码规范 CSS 规范 规范目的 为提高团队协作效率 便于...

  • 网易微专业-页面架构 规范

    1、规范:▪文件规范▪注释规范▪命名规范▪书写规范▪其他规范(HTML和图片) 2、文件规范⑴分类 ⑵引入 ⑶本身...

网友评论

      本文标题:20_RESTful 十大规范

      本文链接:https://www.haomeiwen.com/subject/etgdhqtx.html