激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - Django+RestFramework API接口及接口文檔并返回json數(shù)據(jù)操作

Django+RestFramework API接口及接口文檔并返回json數(shù)據(jù)操作

2020-07-12 21:14xingjidemimi Python

這篇文章主要介紹了Django+RestFramework API接口及接口文檔并返回json數(shù)據(jù)操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧

系統(tǒng):ubuntu18.04 x64

GitHub:https://github.com/xingjidemimi/DjangoAPI.git

安裝

?
1
2
3
pip install django==2.1.5
pip install djangorestframework # rest api
pip install coreapi pygments markdown # 自動化接口文檔

API示例

創(chuàng)建django項(xiàng)目

django-admin startproject DjangoAPI

創(chuàng)建應(yīng)用

cd DjangoAPI

python manage.py startapp apiApp

項(xiàng)目代碼

修改settings.py,添加應(yīng)用到配置中

?
1
2
3
4
5
6
7
8
9
10
INSTALLED_APPS = [
 'django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'rest_framework', # 添加rest_framework應(yīng)用
 'apiApp', # 添加apiApp應(yīng)用
]

執(zhí)行數(shù)據(jù)庫遷移

python manage.py migrate

創(chuàng)建管理員,會提示輸入用戶名:ubuntu,郵箱:[email protected],密碼:ubuntu123456

python manage.py createsuperuser

修改/api/models.py,創(chuàng)建數(shù)據(jù)庫模型。

?
1
2
3
4
5
6
7
8
9
from django.db import models
 
class Test(models.Model):
 name = models.CharField(u'姓名', max_length=100, default='no_name')
 sex = models.CharField(u'性別', max_length=10, default='male')
 age = models.CharField(u'年齡', max_length=3, default='0')
 
 def __unicode__(self):
  return '%d: %s' % (self.pk, self.name)

創(chuàng)建模型后執(zhí)行:

python manage.py makemigrations # 生成數(shù)據(jù)庫遷移文件

python manage.py migrate # 執(zhí)行數(shù)據(jù)庫遷移

修改/api/admin.py,寫后臺管理代碼

?
1
2
3
4
5
6
7
from django.contrib import admin
from apiApp.models import Test
# Register your models here.
 
@admin.register(Test)
class BlogTypeAdmin(admin.ModelAdmin):
 list_display = ('pk', 'name') # 在后臺列表下顯示的字段

運(yùn)行項(xiàng)目

python manage.py runserver

出現(xiàn)如下內(nèi)容表明成功:

?
1
2
3
4
5
System check identified no issues (0 silenced).
January 23, 2019 - 08:28:09
Django version 2.1.5, using settings 'DjangoAPI.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.

瀏覽器輸入:

http://127.0.0.1:8000/ # 出現(xiàn)django成功的界面

http://127.0.0.1:8000/admin # 進(jìn)入管理后臺

序列化模型類,在/api/下創(chuàng)建serializers.py,返回json數(shù)據(jù)

?
1
2
3
4
5
6
7
from rest_framework import serializers
from apiApp.models import Test
 
class TestSerializers(serializers.ModelSerializer):
 class Meta:
  model = Test # 指定的模型類
  fields = ('pk', 'name', 'sex', 'age',) # 需要序列化的屬性

修改/api/views.py,視圖

?
1
2
3
4
5
6
7
8
9
10
11
from django.shortcuts import render
from rest_framework import viewsets
from apiApp.models import Test
from apiApp.serializers import TestSerializers
 
 
class TestViewSet(viewsets.ModelViewSet):
 # 指定結(jié)果集并設(shè)置排序
 queryset = Test.objects.all().order_by('-pk')
 # 指定序列化的類
 serializer_class = TestSerializers

修改/urls.py/,配置主路由

?
1
2
3
4
5
6
7
from django.contrib import admin
from django.urls import path, include
 
urlpatterns = [
 path('admin/', admin.site.urls),
 path('', include('apiApp.urls')), # 添加應(yīng)用的路由地址
]

在/api/下創(chuàng)建urls.py,配置應(yīng)用路由

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
from django.conf.urls import include
from django.urls import path
from rest_framework import routers
from apiApp import views
from rest_framework.documentation import include_docs_urls
 
API_TITLE = 'API Documents'
API_DESCRIPTION = 'API Information'
 
 
# 定義路由地址
route = routers.DefaultRouter()
 
# 注冊新的路由地址
route.register(r'test', views.TestViewSet)
 
# 注冊上一級的路由地址并添加
urlpatterns = [
 path('', include(route.urls)),
 # 接口文檔路由
 path(r'docs/', include_docs_urls(title=API_TITLE, description=API_DESCRIPTION, authentication_classes=[], permission_classes=[]))
]

運(yùn)行項(xiàng)目

python manage.py runserver

打開瀏覽器輸入:

http://127.0.0.1:8000 # api主頁

點(diǎn)擊主頁提供的鏈接http://127.0.0.1:8000/test進(jìn)入下一級目錄

http://127.0.0.1:8000/docs進(jìn)入接口文檔

使用Postman測試工具測試api數(shù)據(jù)

進(jìn)入ubuntusoftware應(yīng)用商店,搜索postman進(jìn)行安裝

在postman中輸入http://127.0.0.1:8000/api/student點(diǎn)擊send,并返回json數(shù)據(jù)。

以上這篇Django+RestFramework API接口及接口文檔并返回json數(shù)據(jù)操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://blog.csdn.net/xingjidemimi/article/details/86694280

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久久久久久亚洲精品 | 亚洲午夜在线 | 伊人成人免费视频 | 免费视频xxxx| 国产精品性夜天天视频 | 中国成人在线视频 | 久久精品中文字幕 | 国产 日韩 亚洲 欧美 | 黄色免费在线网站 | tube69xxxxxhd | 亚洲国产高清一区 | 日韩色视频在线观看 | 亚洲国产精品高潮呻吟久久 | 欧洲成人一区 | 国产精品久久久久久久久久iiiii | 久久精品视频6 | 成人午夜一区二区 | 精品国产乱码一区二区三区四区 | 欧美日本在线视频 | 日本网站在线播放 | 国产91亚洲精品久久久 | 一区二区三区视频在线观看 | 国产精品久久久久久影视 | 在线播放中文 | 中国hd高清xxxxvideo | 人人做人人看 | 成人性生活视频在线播放 | 日韩精品免费看 | 欧美不卡视频在线观看 | 久久爽久久爽久久av东京爽 | 羞羞视频入口 | 久久综合九色 | 羞羞电影在线观看 | 欧美成人精品不卡视频在线观看 | 色吧综合网 | 毛片免费视频播放 | 中国7777高潮网站 | 久艹在线视频 | 国产精品成人亚洲一区二区 | 色精品国产 | 一本色道久久综合亚洲精品小说 |