Rest Framework

一、什么是Restful?
Restful,是一种软件架构风格,REST是Representational State Transfer的简称,我们称为“表征状态转移”,也叫“具象状态转换”。
我们对资源的操作,本质上是对资源的“增删改查”。

    (1)每一个URI代表一种资源;

  (2)客户端和服务器之间,传递这种资源的某种表现层;

  (3)客户端通过四个HTTP动词,对服务器端资源进行操作,实现"表现层状态转化"。

REST设计的优点:
1、前后端分离
2、无状态
3、缓存
4、统一接口
5、支持按需代码

REST是面向资源进行的,而资源是通过URI进行暴露的
URI 的设计只要负责把资源通过合理方式暴露出来就可以了。对资源的操作与它无关,操作是通过 HTTP动词来体现,所以REST 通过 URI 暴露资源时,会强调不要在 URI 中出现动词。

举例:左边是错误的,右边是正确的

GET /rest/api/getDogs --> GET /rest/api/dogs 获取所有小狗 
GET /rest/api/addDogs --> POST /rest/api/dogs 添加一个小狗 
GET /rest/api/editDogs/:dog_id --> PUT /rest/api/dogs/:dog_id 修改一个小狗
GET /rest/api/deleteDogs/:dog_id --> DELETE /rest/api/dogs/:dog_id 删除一个小狗

二、Restful API设计

1、域名:

将 api 部署在专用域名下:
http://api.example.com
或者将 api 放在主域名下:
http://www.example.com/api/

2、版本:

将 API 的版本号放在 url 中。
http://www.example.com/app/1.0/info
http://www.example.com/app/1.2/info

3、路径:

路径表示 API 的具体网址。每个网址代表一种资源。 资源作为网址,网址中不能有动词只能有
名词,一般名词要与数据库的表名对应。而且名词要使用复数。
错误示例:
http://www.example.com/getGoods
http://www.example.com/listOrders
正确示例:
获取单个商品
http://www.example.com/app/goods/1
获取所有商品
http://www.example.com/app/goods

4、使用标准的 HTTP 方法:

对于资源的具体操作类型,由 HTTP 动词表示。 常用的 HTTP 动词有四个。
GET SELECT :从服务器获取资源。
POST CREATE :在服务器新建资源。
PUT UPDATE :在服务器更新资源。
DELETE DELETE :从服务器删除资源。
示例:
获取指定商品的信息
GET http://www.example.com/goods/ID
新建商品的信息
POST http://www.example.com/goods
更新指定商品的信息
PUT http://www.example.com/goods/ID
删除指定商品的信息
DELETE http://www.example.com/goods/ID

5、过滤信息:

如果资源数据较多,服务器不能将所有数据一次全部返回给客户端。API 应该提供参数,过滤返
回结果。 实例:
指定返回数据的数量
http://www.example.com/goods?limit=10
指定返回数据的开始位置
http://www.example.com/goods?offset=10
指定第几页,以及每页数据的数量
http://www.example.com/goods?page=2&per_page=20

6、状态码:

服务器向用户返回的状态码和提示信息,常用的有:
200 OK :服务器成功返回用户请求的数据
201 CREATED :用户新建或修改数据成功。
202 Accepted:表示请求已进入后台排队。
400 INVALID REQUEST :用户发出的请求有错误。
401 Unauthorized :用户没有权限。
403 Forbidden :访问被禁止。
404 NOT FOUND :请求针对的是不存在的记录。
406 Not Acceptable :用户请求的的格式不正确。
500 INTERNAL SERVER ERROR :服务器发生错误。

7、错误信息:

一般来说,服务器返回的错误信息,以键值对的形式返回。
{
 error: 'Invalid API KEY'
}

8、响应结果:

针对不同结果,服务器向客户端返回的结果应符合以下规范。
返回商品列表
GET http://www.example.com/goods
返回单个商品
GET http://www.example.com/goods/cup
返回新生成的商品
POST http://www.example.com/goods
返回一个空文档
DELETE http://www.example.com/goods

9、使用链接关联相关的资源:

在返回响应结果时提供链接其他 API 的方法,使客户端很方便的获取相关联的信息。

10、其他:

服务器返回的数据格式,应该尽量使用 JSON,避免使用 XML。
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django Rest Framework是一个用于构建Web API的强大框架。它可以帮助我们快速开发和管理API接口,并提供了许多有用的功能和工具。安装Django Rest Framework的方法是使用pip3命令进行安装,例如:pip3 install djangorestframework。在项目的settings.py文件中注册Django Rest Framework应用,将'rest_framework'添加到INSTALLED_APPS列表中。此外,还需要进行一些国际化和时区的配置,例如设置LANGUAGE_CODE为'zh-hans',TIME_ZONE为'Asia/Shanghai',并设置USE_I18N为True,USE_L10N为True,USE_TZ为False。你可以使用Django Rest Framework提供的许多功能和组件,如APIView用于定义API视图类,Response用于返回响应数据,Serializer用于定义序列化器,APISettings用于配置API设置,SearchFilter用于搜索过滤,PageNumberPagination用于分页,TokenAuthentication用于身份认证,IsAuthenticated用于权限控制,SimpleRateThrottle用于请求限制等。 Django Rest Framework还支持自定义返回方式,可以根据自己的需求来设计返回的数据格式。它是一个非常方便和强大的框架,特别适用于前后端分离的应用模式,通过定义API接口,可以使前端和后端的交互更加简单和高效。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [REST framework 简介](https://blog.csdn.net/Waller_/article/details/104292515)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [django rest framework 自定义返回方式](https://download.csdn.net/download/weixin_38629274/12849864)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [【rest_framework】入门教程 | 虚拟环境](https://blog.csdn.net/qq_42438771/article/details/107964290)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值