Django中自定義實現restful
什麼是restful api
可以總結為一句話:REST是所有Web應用都應該遵守的架構設計指導原則。 Representational State Transfer,翻譯是”表現層狀態轉化”。 面向資源是REST最明顯的特徵,對於同一個資源的一組不同的操作。REST要求,必須通過統一的介面來對資源執行各種操作。對於每個資源只能執行一組有限的操作。(7個HTTP方法:GET/POST/PUT/DELETE/PATCH/HEAD/OPTIONS)
Restful API設計規範
1,資源
2,統一介面。RESTful風格的資料元操CRUD(create,read,update,delete)分別對應HTTP方法:GET用來獲取資源,POST用來新建資源(也可以用於更新資源),PUT用來更新資源,DELETE用來刪除資源,這樣就統一了資料操作的介面。
3,URI。可以用一個URI(統一資源定位符)指向資源,即每個URI都對應一個特定的資源。要獲取這個資源訪問它的URI就可以,因此URI就成了每一個資源的地址或識別符。一般的,每個資源至少有一個URI與之對應,最典型的URI就是URL。
4,無狀態。所謂無狀態即所有的資源都可以URI定位,而且這個定位與其他資源無關,也不會因為其他資源的變化而變化。有狀態和無狀態的區別,舉個例子說明一下,
例如要查詢員工工資的步驟為第一步:登入系統。第二步:進入查詢工資的頁面。第三步:搜尋該員工。第四步:點選姓名檢視工資。這樣的操作流程就是有狀態的,查詢工資的每一個步驟都依賴於前一個步驟,只要前置操作不成功,後續操作就無法執行。如果輸入一個URL就可以得到指定員工的工資,則這種情況就是無狀態的,因為獲取工資不依賴於其他資源或狀態,且這種情況下,員工工資是一個資源,由一個URL與之對應可以通過HTTP中的GET方法得到資源,這就是典型的RESTful風格。
RESTful API其他一些規範
1:應該將API的版本號放入URL。GET:http://www.xxx.com/v1/friend/123
2:URL中只能有名詞而不能有動詞,URL只標識資源的地址,既然是資源那就是名詞了。
3:如果記錄數量很多,API應該提供引數,過濾返回結果。?limit=10:指定返回記錄的數量、?page=2&per_page=100:指定第幾頁,以及每頁的記錄數。
PS:我介紹的是自定義實現Django restful,當然Django中有一種更快捷、強大的方法,那就是 Django REST framework。它是python的一個模組,通過在Django裡面的配置就可以把app的models中的各個表實現RESTful API。
RESTful API的簡單實現
目錄結構
具體程式碼
準備:先在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)api_v1.py
當請求的方法不同時,會自動根據請求的方法分發到不同的函式方法來執行相應的操作。我這裡只寫了三種方法,要是是這三種以外的方法訪問的話,會報405錯誤,說請求方法不被允許。
urls_api_v1.py:
from django.conf.urls import url from app.api_v1 import * urlpatterns = [ url('^personapi$',PersonAPI.as_view()), ]urls_api_v1.py
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')), ]urls.py