本文将介绍django框架的基本入门使用,下载安装,及实现一个简单的get请求接口和post请求接口,及利用postman和apipost工具进行测试。

一、django介绍

前段时间介绍过轻量级的开发框架flask,以及mock一个简单的 接口。点击查看flask入门。

今天来介绍功能更加强大的django框架。

Django是一个由Python写成的Web应用框架。Django的主要目的是简便、快速的开发数据库驱动的网站。它强调代码复用,多个组件可以很方便的以“插件”形式服务于整个框架,Django有许多功能强大的第三方插件,你甚至可以很方便的开发出自己的工具包。
进入django官网查看更多

二、安装django

2.1 安装

pip install Django==3.2

cmd中执行上面命令,安装最新3.2版本。

2.2 查看版本

pip show django

python django对外接口开发 django写接口_django

2.3 查看django命令

django-admin

python django对外接口开发 django写接口_django_02


我们下面就会用到这两个命令。

三、创建django项目

3.1 创建项目名称

3.1.1 创建根目录

先创建一个目录,如:django_pro,用于存放django项目

3.1.2 创建项目

创建项目:

django-admin startproject dj_pro

命令中最后“dj_jpro"是项目名。

创建成功后,我们可以查看我们的项目目录变化:

python django对外接口开发 django写接口_postman_03


创建项目中,新建项目名称目录及manage.py文件。

再次展开dj_pro目录后:

python django对外接口开发 django写接口_创建项目_04


后续,我们就会用到上面的文件,暂时先不管它们。

3.1.3 创建app

可能很多人会有疑问,什么是app?我们以django官网为例:

python django对外接口开发 django写接口_postman_05


这上面箭头,每一个都可以理解为一个app。

创建命令:

django-admin startapp dj_api

命令最后”dj_api”是app名。创建成功后,我们再次查看目录:

python django对外接口开发 django写接口_postman_06


与项目目录大同小民,又稍有不同。暂时先不管它们。

创建成功app后,我们另一个命令闪亮全场了:

python manage.py

python django对外接口开发 django写接口_创建项目_07


切换到项目中,使用上面命令,将是我们常用到的。最常用的当然是启动服务。

3.1.4 设置中添加app

创建app后,我们需要到项目文件settings文件中增加我们的app名:

python django对外接口开发 django写接口_django_08

3.1.5 启动django服务

执行命令:

python manage.py runserver

python django对外接口开发 django写接口_python django对外接口开发_09


可以看到,django已经启动成功,默认端口是8000.我们进入浏览器中查看:

python django对外接口开发 django写接口_postman_10


如果,显示这个页面,说明django服务已经启动成功了。

3.2 创建API

3.2.1 展示hello django

先来展示一个简单的hello django页面:

服务启动后,我们在ip中加入hello:

python django对外接口开发 django写接口_django_11


这是为啥呢?要怎么才能看到hello django页面呢?

这时,我们需要到项目的urls.py文件中查看定义的路径。

python django对外接口开发 django写接口_python django对外接口开发_12


这里只定义了一个admin,那好,我们访问一下admin,看看效果:

python django对外接口开发 django写接口_django_13


访问成功。那我们知道了。我们需要先定义一个路由:

A. 我们在项目中urls.py文件,添加路由:

python django对外接口开发 django写接口_创建项目_14


B. 在app的视图views.py文件中,输入页面响应内容:

from django.http import HttpResponse

def hello(request):
    return HttpResponse("Hello django. I am comming.")

如下:

python django对外接口开发 django写接口_python_15


C. 访问页面

python django对外接口开发 django写接口_django_16


OK了。第一个django页面实现了。

够不够清楚了呢?如果不够,再来:

我们再将上面的例子,改装一下:

A. 项目中urls.py文件中,更改:

python django对外接口开发 django写接口_python django对外接口开发_17


我们更改,是让后续所有的接口,都在dj_rpi下面。

B. 我们再在app中创建一个urls.py文件,代码如下:

python django对外接口开发 django写接口_postman_18

C. 最后将视图中views.py文件,改成接口类型:

python django对外接口开发 django写接口_python django对外接口开发_19


D. 访问浏览器

python django对外接口开发 django写接口_创建项目_20


OK.我们实现了一个get请求的接口。

3.2.2 实现get请求的接口

在app的views.py文件中,编写代码:

from django.http import JsonResponse


def get_user(request):
    if request.method == 'GET':
        usid = request.GET.get('usid','')
        if usid=='':
            return JsonResponse({'code':100101,'msg':'用户id不能为空'})
        if usid=='1':
            return JsonResponse({'code':100200,'msg':'查询成功','data':{'usid':1,'name':'james','age':36}})
        else:
            return JsonResponse({'code':100102,'msg':'未查询到用户数据'})

    else:
        return JsonResponse({'code': 100103, 'msg': '请求方法错误'})

3.2.3 测试get请求

我们利用postman工具进行测试,自行安装postman工具:

A. 请求方法错误

python django对外接口开发 django写接口_postman_21


B. 参数为空

python django对外接口开发 django写接口_postman_22


C. 参数不正确

python django对外接口开发 django写接口_python_23


D. 查询成功

python django对外接口开发 django写接口_postman_24

3.2.4 实现post请求的接口

代码如下:

from django.http import JsonResponse

def add_user(request):
    if request.method == 'POST':
        usid = request.POST.get('usid','')
        name = request.POST.get('name','')
        if usid=='' or name=='':
            return JsonResponse({'code':100101,'msg':'用户id或密码不能为空'})
        if usid=='1' and name=='james':
            return JsonResponse({'code':100200,'msg':'添加成功','data':{'usid':1,'name':'james','age':36}})
        else:
            return JsonResponse({'code':100102,'msg':'添加失败'})

    else:
        return JsonResponse({'code': 100103, 'msg': '请求方法错误'})

3.2.5 测试post请求

换个工具,apipost测试工具:

A. 请求方法不对

python django对外接口开发 django写接口_django_25


B. 参数空

python django对外接口开发 django写接口_python_26


C. 参数错误

python django对外接口开发 django写接口_postman_27


D. 添加成功

python django对外接口开发 django写接口_python_28

四、报错解决:

1. 提示CSRF报错

python django对外接口开发 django写接口_创建项目_29


解决:

python django对外接口开发 django写接口_创建项目_30


在项目的settings.py文件中,找到这一行,注释掉。就OK了。

2. Bad Request

python django对外接口开发 django写接口_创建项目_31


解决:

python django对外接口开发 django写接口_postman_32


同样的settings.py文件中,添加*

python django对外接口开发 django写接口_postman_33


简单的django框架介绍,暂时介绍到这里。但是,这些数据是随便加的,并没有跟数据库连接起来,下一期,将针对数据库再深入实现接口及测试接口。