項目實戰(zhàn)——通過Django實現(xiàn)簡單的 增刪改查 后端API接口

一旨涝、環(huán)境準(zhǔn)備

1. Python

2. Django

通過命令:pip install django即可安裝最新版本的Django县貌。
如果速度太慢可切換為國內(nèi)鏡像下載:pip install django -i http://mirrors.aliyun.com/pypi/simple升薯。

3. MySQL

二膏秫、構(gòu)建Django項目

1. 新建Django項目

新建一個名稱為 djangoDemo 的項目喘落。

django-admin.py startproject djangoDemo

2. 創(chuàng)建app

進(jìn)入項目根目錄规伐,創(chuàng)建一個名稱為 myapp 的app蟹倾。

python manage.py startapp myapp

目錄結(jié)構(gòu):

在這里插入圖片描述

3. 數(shù)據(jù)庫信息關(guān)聯(lián)配置

打開 djangoDemo 目錄下的 settings.py 配置文件,把默認(rèn)的sqllite3數(shù)據(jù)庫換成我們的MySQL數(shù)據(jù)庫:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql', # 數(shù)據(jù)庫引擎 
        'NAME': 'djangoDB', # 數(shù)據(jù)庫名稱 
        'USER': 'root', # 用戶名
        'PASSWORD': '123456', # 密碼
        'HOST': '127.0.0.1', # 主機(jī)IP地址
        'PORT': '3306' # 默認(rèn)端口
    }
}

并把a(bǔ)pp加入到INSTALLED_APPS列表里:

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'myapp' # 加入app
]

4. 修改 myapp 文件夾中的 models.py

from django.db import models


# Create your models here.

class Person(models.Model):
    person_name = models.CharField('姓名', max_length=64, null=False)
    deposit = models.FloatField('存款')
    add_time = models.DateTimeField(auto_now_add=True)
    isDelete = models.BooleanField(default=False)

    def __str__(self):
        return self.person_name, self.deposit

只有四個字段猖闪,人名person_name鲜棠、存款deposit、添加時間add_time以及刪除標(biāo)識isDelete培慌。如果沒有指定主鍵的話django會自動新增一個自增id作為主鍵豁陆。

5. 添加接口

myapp 目錄下的 views.py 里我們新增兩個接口:
add_person:接受一個get請求,往數(shù)據(jù)庫里添加一條person數(shù)據(jù)吵护;
show_persons:返回所有的人物列表(通過JsonResponse返回能被前端識別的json格式數(shù)據(jù))盒音。

from django.shortcuts import render
from django.views.decorators.http import require_http_methods
from django.core import serializers
from django.http import JsonResponse
import json

from .models import Person


# Create your views here.
@require_http_methods(["GET"])
def add_person(request):
    response = {}
    try:
        person = Person(
            person_name=request.GET.get('person_name'), 
            deposit=request.GET.get('deposit')
        )
        person.save()
        response['msg'] = 'success'
        response['error_num'] = 0
    except Exception as e:
        response['msg'] = str(e)
        response['error_num'] = 1
    return JsonResponse(response)


@require_http_methods(["GET"])
def show_persons(request):
    response = {}
    try:
        persons = Person.objects.filter()
        response['list'] = json.loads(serializers.serialize("json", persons))
        response['msg'] = 'success'
        response['error_num'] = 0
    except Exception as e:
        response['msg'] = str(e)
        response['error_num'] = 1
    return JsonResponse(response)

6. 路由關(guān)聯(lián)

① 在 myapp 目錄下,新增一個 urls.py 文件馅而,把我們新增的兩個接口添加到路由里:

from django.conf.urls import url, include
from myapp import views

urlpatterns = [
    url(r'add_person$', views.add_person, ),
    url(r'show_persons$', views.show_persons, ),
]

② 我們還要把 myapp 下的 urls.py 添加到 djangoDemo 下的 urls.py 中里逆,才能完成路由關(guān)聯(lián)。

from django.contrib import admin
from django.urls import path
from django.conf.urls import url, include
import myapp.urls

urlpatterns = [
    path('admin/', admin.site.urls),
    # url(r'^api/', include(myapp.urls)),
    url(r'^', include(myapp.urls)),
]

7. 同步所有數(shù)據(jù)表

進(jìn)入項目根目錄用爪,同步數(shù)據(jù)表

# 進(jìn)入包含有 manage.py 的文件夾
python manage.py makemigrations
python manage.py migrate

在這里,Python3.* 如未安裝MySQLdb模塊胁镐,會出現(xiàn)報錯偎血。
解決辦法請看:踩坑心得——Python3.* 報錯“ImportError: No module named ‘MySQLdb'”

8. 啟動服務(wù)

在項目的根目錄,輸入命令:

python manage.py runserver

啟動服務(wù)盯漂,通過postman測試一下我們剛才寫的兩個接口:
add_person

在這里插入圖片描述

刷新數(shù)據(jù)庫颇玷,發(fā)現(xiàn)數(shù)據(jù)已新增存儲:
在這里插入圖片描述

show_persons

在這里插入圖片描述

至此,新增以及查詢的后端API接口已完成就缆。

本地Django項目部署至服務(wù)器的詳細(xì)步驟請見:項目實戰(zhàn)——本地Django項目(后端)部署至騰訊云服務(wù)器/CentOS 7

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末帖渠,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子竭宰,更是在濱河造成了極大的恐慌空郊,老刑警劉巖份招,帶你破解...
    沈念sama閱讀 212,222評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異狞甚,居然都是意外死亡锁摔,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,455評論 3 385
  • 文/潘曉璐 我一進(jìn)店門哼审,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谐腰,“玉大人,你說我怎么就攤上這事涩盾∈” “怎么了?”我有些...
    開封第一講書人閱讀 157,720評論 0 348
  • 文/不壞的土叔 我叫張陵春霍,是天一觀的道長砸西。 經(jīng)常有香客問我,道長终畅,這世上最難降的妖魔是什么籍胯? 我笑而不...
    開封第一講書人閱讀 56,568評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮离福,結(jié)果婚禮上杖狼,老公的妹妹穿的比我還像新娘。我一直安慰自己妖爷,他們只是感情好蝶涩,可當(dāng)我...
    茶點故事閱讀 65,696評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著絮识,像睡著了一般绿聘。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上次舌,一...
    開封第一講書人閱讀 49,879評論 1 290
  • 那天熄攘,我揣著相機(jī)與錄音,去河邊找鬼彼念。 笑死挪圾,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的逐沙。 我是一名探鬼主播哲思,決...
    沈念sama閱讀 39,028評論 3 409
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼吩案!你這毒婦竟也來了棚赔?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,773評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎靠益,沒想到半個月后丧肴,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,220評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡捆毫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,550評論 2 327
  • 正文 我和宋清朗相戀三年闪湾,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绩卤。...
    茶點故事閱讀 38,697評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡途样,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出濒憋,到底是詐尸還是另有隱情何暇,我是刑警寧澤,帶...
    沈念sama閱讀 34,360評論 4 332
  • 正文 年R本政府宣布凛驮,位于F島的核電站裆站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏黔夭。R本人自食惡果不足惜宏胯,卻給世界環(huán)境...
    茶點故事閱讀 40,002評論 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望本姥。 院中可真熱鬧肩袍,春花似錦、人聲如沸婚惫。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,782評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽先舷。三九已至艰管,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蒋川,已是汗流浹背牲芋。 一陣腳步聲響...
    開封第一講書人閱讀 32,010評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留捺球,地道東北人街图。 一個月前我還...
    沈念sama閱讀 46,433評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像懒构,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子耘擂,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,587評論 2 350

推薦閱讀更多精彩內(nèi)容