1. 程式人生 > >Django中自定義實現restful

Django中自定義實現restful

什麼是restful api

  可以總結為一句話:REST是所有Web應用都應該遵守的架構設計指導原則。 Representational State Transfer,翻譯是”表現層狀態轉化”。 面向資源是REST最明顯的特徵,對於同一個資源的一組不同的操作。REST要求,必須通過統一的介面來對資源執行各種操作。對於每個資源只能執行一組有限的操作。(7個HTTP方法:GET/POST/PUT/DELETE/PATCH/HEAD/OPTIONS)

Restful API設計規範

1,資源。首先是弄清楚資源的概念。資源就是網路上的一個實體,一段文字,一張圖片或者一首歌曲。資源總是要通過一種載體來反應它的內容。JSON是現在最常用的資源表現形式。

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

。或者將版本號放在HTTP頭資訊中。

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