能够总结为一句话:REST是全部Web应用都应该遵照的架构设计指导原则。 Representational State Transfer,翻译是”表现层状态转化”。 面向资源是REST最明显的特征,对于同一个资源的一组不一样的操做。REST要求,必须经过统一的接口来对资源执行各类操做。对于每一个资源只能执行一组有限的操做。(7个HTTP方法:GET/POST/PUT/DELETE/PATCH/HEAD/OPTIONS)python
1,资源django
2,统一接口。RESTful风格的数据元操CRUD(create,read,update,delete)分别对应HTTP方法:GET用来获取资源,POST用来新建资源(也能够用于更新资源),PUT用来更新资源,DELETE用来删除资源,这样就统一了数据操做的接口。api
3,URI。能够用一个URI(统一资源定位符)指向资源,即每一个URI都对应一个特定的资源。要获取这个资源访问它的URI就能够,所以URI就成了每个资源的地址或识别符。通常的,每一个资源至少有一个URI与之对应,最典型的URI就是URL。restful
4,无状态。所谓无状态即全部的资源均可以URI定位,并且这个定位与其余资源无关,也不会由于其余资源的变化而变化。有状态和无状态的区别,举个例子说明一下,网络
例如要查询员工工资的步骤为第一步:登陆系统。第二步:进入查询工资的页面。第三步:搜索该员工。第四步:点击姓名查看工资。这样的操做流程就是有状态的,查询工资的每个步骤都依赖于前一个步骤,只要前置操做不成功,后续操做就没法执行。若是输入一个URL就能够获得指定员工的工资,则这种状况就是无状态的,由于获取工资不依赖于其余资源或状态,且这种状况下,员工工资是一个资源,由一个URL与之对应能够经过HTTP中的GET方法获得资源,这就是典型的RESTful风格。架构
1:应该将API的版本号放入URL。GET:http://www.xxx.com/v1/friend/123。或者将版本号放在HTTP头信息中。app
2:URL中只能有名词而不能有动词,URL只标识资源的地址,既然是资源那就是名词了。ide
3:若是记录数量不少,API应该提供参数,过滤返回结果。?limit=10:指定返回记录的数量、?page=2&per_page=100:指定第几页,以及每页的记录数。函数
PS:我介绍的是自定义实现Django restful,固然Django中有一种更快捷、强大的方法,那就是 Django REST framework。它是python的一个模块,经过在Django里面的配置就能够把app的models中的各个表实现RESTful API。
post
准备:先在models中建一个Person类插入一些数据。
api_v1.py:
from django.forms import model_to_dict from django.http import QueryDict, JsonResponse from django.views.generic import View from app.models import * class PersonAPI(View): def get(self,req): data = Person.objects.all() person = [model_to_dict(i) for i in data] result = { 'code':1, 'msg':'数据查询到了', 'data':person } return JsonResponse(result) def post(self,req): name = req.POST.get('name') age = req.POST.get('age') res = Person.objects.create(name = name,age = age) result = { 'code':1, 'msg':'数据建立成功', 'data':model_to_dict(res) } return JsonResponse(result) def delete(self,req): params = QueryDict(req.body) id = int(params.get('s_id')) res = Person.objects.get(pk=id) res.delete() result = { 'code':1, 'msg':'数据删除成功', 'data':id } return JsonResponse(result)
当请求的方法不一样时,会自动根据请求的方法分发到不一样的函数方法来执行相应的操做。我这里只写了三种方法,要是是这三种之外的方法访问的话,会报405错误,说请求方法不被容许。
urls_api_v1.py:
from django.conf.urls import url from app.api_v1 import * urlpatterns = [ url('^personapi$',PersonAPI.as_view()), ]
urls.py:
from django.conf.urls import url,include from django.contrib import admin urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^api/v1/', include('app.urls_api_v1')), ]