1.Django REST framework框架介绍
- Django REST framework框架是一个功能强大且灵活的工具包,用于构建Web API,且Django Rest Framework 是 Django 依赖扩展 Restful Api 的框架,与Django的使用风格类似,它的官方网站是:https://www.django-rest-framework.org/
2.设计API
我们先选择一个APP,比如说我选择的是schools APP,如何在设计这个APP中设计一个API接口,且在前端请求的时候,返回数据库中所有学校的详细信息呢?
- 第一步:首先需要在项目的urls.py文件(根路由)中添加二级路由;
url(r'^school/', include('schools.urls', namespace='schools'))
- 第二步:在schools APP中的urls.py文件添加路由,指定访问路径,需要导入AllSchoolsView类,AllSchoolsView类是在view.py文件中编写,(记得执行makemigration 和 migrate操作)
url(r'^all/$', AllSchoolsView.as_view(), name='all')
-
第三步:在schools APP中的views.py文件中,
编写AllSchoolsView类
;
from django.views.generic.base import View
import json
from django.core.serializers import serialize
from django.http import HttpResponse, JsonResponse
from .models import School
class AllSchoolsView(View):
def get(self, request):
schools = School.objects.all()
# 直接将数据库中的QuerySet对象转换为json数据格式
goods_json = serialize('json', schools)
print(type(goods_json))
print('serialize: --------{}'.format(goods_json))
return HttpResponse(content=goods_json, content_type='application/json')
- 第四步:在schools APP中的models.py文件中,根据需求创建schools_school表;
from django.db import models
from datetime import datetime
class School(models.Model):
name = models.CharField(max_length=50, verbose_name='学校名称')
desc = models.CharField(max_length=100, verbose_name='学校描述')
location = models.CharField(max_length=100, verbose_name='学校位置')
create_time = models.DateTimeField(default=datetime.now, verbose_name='添加时间')
course_numbers = models.IntegerField(default=0, verbose_name="课程数")
创建数据库表前面的文章也讲过,这里就不讲了,数据库表创建好了之后我们可以往里面增加数据,可以使用命令行添加,但是这样比较麻烦,所以这里我们数据库管理和设计工具Navicat(文章最后介绍),使用这个工具我们可以手动增加修改数据库表中的数据,特别方便;
首先需要选择一个待使用的数据库,我使用的是MySql,然后创建连接,再填写一下选项就可以了:
- 第五步:创建数据库中schools_school表的数据,可以通过Navicat来操作数据库,最后我们的数据库表示这样的:
-
第六步:运行项目,就能得到我们想要的json数据了,访问路径是
http://127.0.0.1:8000/schools/all/
;
3.使用Django REST framework定制Restful API
- 第一步:首先安装好需要用到的包;
pip install djangorestframework
pip install markdown # Markdown support for the browsable API.
pip install django-filter # Filtering support
- 第二步:然后在项目的settings文件的INSTALLED_APPS中添加rest_framewor;
INSTALLED_APPS = (
'rest_framework',
)
- 第三步:在根路由urls.py中加一条路由,用于支持浏览器访问api认证;
url(r'^api-auth/', include('rest_framework.urls'))
-
第四步:创建Django的管理员,
选择Tool->Run manage.py Task
,然后执行createsuperuser
,编辑自己的用户名、邮箱和密码就可以了; -
第五步:在schools APP中创建
serializer.py
文件,在这个文件中导入serializers模块
,然后创建一个序列化类(自己命名),让这个类继承serializers模块
下的Serializer类;
from rest_framework import serializers
class SchoolSerializer(serializers.Serializer):
name = serializers.CharField()
course_numbers = serializers.IntegerField()
- 第六步:在schools APP中的views.py文件中重写AllSchoolsView类,重启服务器就能得到Django REST framework返回的数据了;
from .models import School
from rest_framework.views import APIView
from rest_framework.response import Response
from .serializer import SchoolSerializer
class AllSchoolsView(APIView):
def get(self, request):
schools = School.objects.all()
# many表示返回一个list, 如果不设置,则返回一个
schools_serializer = SchoolSerializer(schools, many=True)
return Response(schools_serializer.data)
4.Navicat
- Navicat是一套可创建多个连接的数据库管理工具,用以方便管理
MySQL、Oracle、 PostgreSQL、SQLite、SQL Server、MariaDB 和/或 MongoDB
等不同类型的数据库,并 支持管理某些云数据库,例如阿里云、腾讯云; - Navicat 提供了三种平台的版本
Windows、macOS 、Linux
,可以让用户连接到本地或远 程服务器,并提供一些实用的数据库工具以协助用户管理数据,包括 Navicat Cloud 协同合 作、数据建模、数据传输、数据同步、结构同步、导入、导出、备份、还原和自动运行; - 想了解更多用法可以查看官网,官网地址:https://www.navicat.com/en/
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。