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

作者:乔路非 时间:2022-05-17 02:36:53 

数据库中有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接口

来源:https://blog.csdn.net/qq_40731976/article/details/108823765

标签:Django,RESTful,API,增删改查
0
投稿

猜你喜欢

  • 完美解决phpstudy安装后mysql无法启动(无需删除原数据库,无需更改任何配置,无需更改端口)直接共存

    2023-11-14 17:39:47
  • 如何调用Oracle存储过程?

    2009-11-15 20:13:00
  • php filter协议使用方法

    2023-05-29 19:36:40
  • ASP中的面向对象类

    2011-04-11 10:34:00
  • ASP实现全站的301跳转

    2010-03-27 21:45:00
  • python GUI库图形界面开发之PyQt5动态(可拖动控件大小)布局控件QSplitter详细使用方法与实例

    2023-06-20 22:10:04
  • Python asyncio异步编程简单实现示例

    2023-09-23 15:27:52
  • 简单的asp采集代码教程

    2011-04-18 10:39:00
  • Python+matplotlib实现简单曲线的绘制

    2023-01-05 17:21:27
  • WinHTTP Services 5.1 参考资料

    2010-03-27 20:49:00
  • MySQL中随机生成固定长度字符串的方法

    2010-12-08 16:25:00
  • IE中jscript/javascript的条件编译

    2007-10-03 14:03:00
  • Java与Python之间使用jython工具类实现数据交互

    2023-10-06 18:44:09
  • 重新认识视觉设计

    2009-09-08 12:46:00
  • Python实现图像增强

    2022-07-08 10:50:50
  • ASP调用数据库常见错误的解决

    2007-09-07 10:05:00
  • PHP常用函数之获取汉字首字母功能示例

    2023-06-16 12:24:39
  • 浅谈python print(xx, flush = True) 全网最清晰的解释

    2022-01-28 21:45:48
  • 解决SQL Server的“此数据库没有有效所有者”问题

    2011-12-14 18:29:35
  • WEB2.0网页制作标准教程(10)自适应高度

    2008-02-19 19:21:00
  • asp之家 网络编程 m.aspxhome.com