Django开发RESTful API实现增删改查(入门级)


Posted in Python onMay 10, 2021

数据库中有user表如下:

Django开发RESTful API实现增删改查(入门级)

新建一个Django项目:

django-admin.py startproject myDjango<project_name>

目录介绍

myDjango/
├── manage.py  # 管理文件
└── myDjango # 项目目录
    ├── __ init __.py
    ├── settings.py  # 配置文件
    ├── urls.py  # 路由 --> URL和函数的对应关系
    └── wsgi.py  # runserver命令就使用wsgiref模块做简单的web server

使用rest_framework

在setting.py中添加:

INSTALLED_APPS = [
   ...
   'rest_framework'
]

连接MySQL数据库

在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 users<app_name>

目录介绍:

users/
├── migrations  # 用于在之后定义引用迁移功能
   ├── __ init __.py
├── __ init __.py
├── admin.py  # 管理站点模型的声明文件,默认为空
├── apps.py  # 应用信息定义文件。在其中生成了类Appconfig,类用于定义应用名等Meta数据
├── models.py  # 添加模型层数据类的文件
├── tests.py  # 测试代码文件
└── views.py  # 定义URL响应函数

在setting.py中添加:

INSTALLED_APPS = [
    ...
    'users'
]

把数据库中的表生成对应的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'

创建一个序列化Serializer类,使之可以转化为,某种表现形式如json

在users目录下,创建文件serializers.py

from rest_framework import serializers
from users.models import User

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

数据输出

编写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):  # 获取全部数据
    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):  # 根据id查找单条数据
    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):  # 添加数据
    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):  # 根据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):  # 根据id修改数据
    if User.objects.filter(id=request.data['id']):
        user = User.objects.get(id=request.data['id'])
        ser = UserSerializer(instance=user, data=request.data)  # 注意指定参数
        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

访问结果:

Django开发RESTful API实现增删改查(入门级)

Django开发RESTful API实现增删改查(入门级)

源码地址: myDjango

参考:
创建第一个Django项目
Python用Django写restful api接口

到此这篇关于Django开发RESTful API实现增删改查(入门级)的文章就介绍到这了,更多相关Django RESTful API增删改查内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python的Template使用指南
Sep 11 Python
Python使用django框架实现多人在线匿名聊天的小程序
Nov 29 Python
python数据抓取分析的示例代码(python + mongodb)
Dec 25 Python
Django实现全文检索的方法(支持中文)
May 14 Python
python如何爬取个性签名
Jun 19 Python
Python实现曲线拟合操作示例【基于numpy,scipy,matplotlib库】
Jul 12 Python
Python实现插入排序和选择排序的方法
May 12 Python
11个Python3字典内置方法大全与示例汇总
May 13 Python
pyqt5 tablewidget 利用线程动态刷新数据的方法
Jun 17 Python
Django错误:TypeError at / 'bool' object is not callable解决
Aug 16 Python
Python scipy的二维图像卷积运算与图像模糊处理操作示例
Sep 06 Python
pytorch方法测试详解——归一化(BatchNorm2d)
Jan 15 Python
Python中X[:,0]和X[:,1]的用法
May 10 #Python
Python Django搭建文件下载服务器的实现
详解python的内存分配机制
May 10 #Python
python-for x in range的用法(注意要点、细节)
May 10 #Python
Django显示可视化图表的实践
python 中[0]*2与0*2的区别说明
May 10 #Python
Python超简单容易上手的画图工具库推荐
You might like
rephactor 优秀的PHP的重构工具
2011/06/09 PHP
Discuz!X中SESSION机制实例详解
2015/09/23 PHP
浅析PHP数据导出知识点
2018/02/17 PHP
jquery关于页面焦点的定位(文本框获取焦点时改变样式 )
2010/09/10 Javascript
ECMAScript 创建自己的js类库
2012/11/22 Javascript
js调用AJAX时Get和post的乱码解决方法
2013/06/04 Javascript
javascript禁制后退键(Backspace)实例代码
2013/11/15 Javascript
javascript中活灵活现的Array对象详解
2016/11/30 Javascript
bootstrap suggest下拉框使用详解
2017/04/10 Javascript
JS获取填报扩展单元格控件的值的解决办法
2017/07/14 Javascript
JS实现生成由字母与数字组合的随机字符串功能详解
2018/05/25 Javascript
在create-react-app中使用css modules的示例代码
2018/07/31 Javascript
JS实现点击li标签弹出对应的索引功能【案例】
2019/02/18 Javascript
vue实现按需加载组件及异步组件功能
2019/05/27 Javascript
JS实现的进制转换,浮点数相加,数字判断操作示例
2019/11/09 Javascript
用Python代码来绘制彭罗斯点阵的教程
2015/04/03 Python
Python的Flask框架中Flask-Admin库的简单入门指引
2015/04/07 Python
Python 实现文件的全备份和差异备份详解
2016/12/27 Python
Python3.6通过自带的urllib通过get或post方法请求url的实例
2018/05/10 Python
dataframe 按条件替换某一列中的值方法
2019/01/29 Python
django 捕获异常和日志系统过程详解
2019/07/18 Python
Python 使用 PyMysql、DBUtils 创建连接池提升性能
2019/08/14 Python
python基于event实现线程间通信控制
2020/01/13 Python
Python编写单元测试代码实例
2020/09/10 Python
Python extract及contains方法代码实例
2020/09/11 Python
Python私有属性私有方法应用实例解析
2020/09/15 Python
python温度转换华氏温度实现代码
2020/12/06 Python
纯CSS3实现带动画效果导航菜单无需js
2013/09/27 HTML / CSS
Book Depository欧盟:一家领先的国际图书零售商
2019/05/21 全球购物
个人简历自我评价八例
2013/10/31 职场文书
前台文员的岗位职责
2013/11/14 职场文书
青年志愿者先进事迹
2014/05/06 职场文书
2014年保育员工作总结
2014/12/02 职场文书
Go标准容器之Ring的使用说明
2021/05/05 Golang
CSS 实现多彩、智能的阴影效果
2021/05/12 HTML / CSS
Windows中Redis安装配置流程并实现远程访问功能
2021/06/07 Redis