主頁 > 知識庫 > Django開發(fā)RESTful API實現(xiàn)增刪改查(入門級)

Django開發(fā)RESTful API實現(xiàn)增刪改查(入門級)

熱門標簽:公司電話機器人 唐山智能外呼系統(tǒng)一般多少錢 廣告地圖標注app 白銀外呼系統(tǒng) 陜西金融外呼系統(tǒng) 騰訊外呼線路 哈爾濱ai外呼系統(tǒng)定制 海南400電話如何申請 激戰(zhàn)2地圖標注

數(shù)據(jù)庫中有user表如下:

新建一個Django項目:

django-admin.py startproject myDjangoproject_name>

目錄介紹

myDjango/
├── manage.py  # 管理文件
└── myDjango # 項目目錄
    ├── __ init __.py
    ├── settings.py  # 配置文件
    ├── urls.py  # 路由 --> URL和函數(shù)的對應關系
    └── wsgi.py  # runserver命令就使用wsgiref模塊做簡單的web server

使用rest_framework

在setting.py中添加:

INSTALLED_APPS = [
   ...
   'rest_framework'
]

連接MySQL數(shù)據(jù)庫

在setting.py中設置:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'bigdatatest',
        'USER': 'root',
        'HOST': '127.0.0.1',
        'PASSWORD': '1009',
        'PORT': 3306,
        'OPTIONS': {'charset': 'utf8mb4'},
    }
}

在__init__.py中添加:

import pymysql
pymysql.version_info = (1, 4, 13, "final", 0)
pymysql.install_as_MySQLdb()

新建app

python manage.py startapp usersapp_name>

目錄介紹:

users/
├── migrations  # 用于在之后定義引用遷移功能
   ├── __ init __.py
├── __ init __.py
├── admin.py  # 管理站點模型的聲明文件,默認為空
├── apps.py  # 應用信息定義文件。在其中生成了類Appconfig,類用于定義應用名等Meta數(shù)據(jù)
├── models.py  # 添加模型層數(shù)據(jù)類的文件
├── tests.py  # 測試代碼文件
└── views.py  # 定義URL響應函數(shù)

在setting.py中添加:

INSTALLED_APPS = [
    ...
    'users'
]

把數(shù)據(jù)庫中的表生成對應的model

python manage.py inspectdb

將我們表的model拷貝到users下的models.py里

from django.db import models

class User(models.Model):
    id = models.IntegerField(primary_key=True)
    name = models.CharField(max_length=255, blank=True, null=True)
    age = models.IntegerField(blank=True, null=True)

    class Meta:
        managed = False
        db_table = 'user'

創(chuàng)建一個序列化Serializer類,使之可以轉化為,某種表現(xiàn)形式如json

在users目錄下,創(chuàng)建文件serializers.py

from rest_framework import serializers
from users.models import User

class UserSerializer(serializers.ModelSerializer):
    class Meta:
        model = User
        fields = "__all__"

數(shù)據(jù)輸出

編寫users下的views.py

from __future__ import unicode_literals

from rest_framework.decorators import api_view
from rest_framework.response import Response

from user.models import User
from user.serializers import UserSerializer

@api_view(['GET'])
def getlist(request):  # 獲取全部數(shù)據(jù)
    if request.method == 'GET':
        users = User.objects.values('id', 'name', 'age').distinct()
        serializer = UserSerializer(users, many=True)
        return Response(serializer.data)

@api_view(['GET'])
def getlistpic(request):  # 根據(jù)id查找單條數(shù)據(jù)
    id = request.GET['id']
    if id is not None:
        users = User.objects.filter(id=id)
        serializer = UserSerializer(users, many=True)
        return Response(serializer.data)
    else:
        return Response(str('請傳id'))

@api_view(['POST'])
def addUser(request):  # 添加數(shù)據(jù)
    ser = UserSerializer(data=request.data)
    if ser.is_valid():
       ser.save()
       return Response(ser.data)
    return Response(ser.errors)

@api_view(['GET'])
def deleteUser(request):  # 根據(jù)id添加刪除
    id = request.GET['id']
    if id is not None:
        if User.objects.filter(id=id):
            User.objects.get(id=id).delete()
            return Response(str('success'))
        else:
            return Response(str('沒有此id'))
    else:
        return Response(str('請傳id'))

@api_view(['POST'])
def updateUser(request):  # 根據(jù)id修改數(shù)據(jù)
    if User.objects.filter(id=request.data['id']):
        user = User.objects.get(id=request.data['id'])
        ser = UserSerializer(instance=user, data=request.data)  # 注意指定參數(shù)
        if ser.is_valid():
            ser.save()
            return Response(str('success'))
        return Response(ser.errors)
    return Response(str('沒有此id'))

在urls.py中設置:

from django.conf.urls import url
from users import views as users_views
urlpatterns = [
    url(r'^getlistpic', users_views.getlistpic, name='home'),
    url(r'^getlist', users_views.getlist, name='home'),
    url(r'^addUser', users_views.addUser, name='home'),
    url(r'^deleteUser', users_views.deleteUser, name='home'),
    url(r'^updateUser', users_views.updateUser, name='home')
]

啟動項目:

python manage.py runserver 127.0.0.1:8000

訪問結果:


源碼地址: myDjango

參考:
創(chuàng)建第一個Django項目
Python用Django寫restful api接口

到此這篇關于Django開發(fā)RESTful API實現(xiàn)增刪改查(入門級)的文章就介紹到這了,更多相關Django RESTful API增刪改查內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • go 原生http web 服務跨域restful api的寫法介紹
  • Django restful framework生成API文檔過程詳解
  • Django JWT Token RestfulAPI用戶認證詳解
  • Python利用Django如何寫restful api接口詳解
  • 詳解Django rest_framework實現(xiàn)RESTful API
  • 詳解Go語言RESTful JSON API創(chuàng)建
  • 基于Go語言構建RESTful API服務

標簽:上海 黑龍江 常德 四川 惠州 鷹潭 黔西 益陽

巨人網(wǎng)絡通訊聲明:本文標題《Django開發(fā)RESTful API實現(xiàn)增刪改查(入門級)》,本文關鍵詞  Django,開發(fā),RESTful,API,實現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Django開發(fā)RESTful API實現(xiàn)增刪改查(入門級)》相關的同類信息!
  • 本頁收集關于Django開發(fā)RESTful API實現(xiàn)增刪改查(入門級)的相關信息資訊供網(wǎng)民參考!
  • 推薦文章