目的

利用django搭建一个WebApi,实现数据库表的增删查改。

数据传输基于Http协议,数据格式:JSON

ORM方式进行数据库表的CRUD(增删查改)

开发步骤

使用pycharm专业版搭建一个django项目,File-->newProject



专业版的使用需要注册码,网上自己下载即可

项目与应用

当前生成的项目只是一个框架啊,具体的实现方法在应用中

创建应用

python manage.py startapp apitest  #apitest是应用名

django项目中使用应用

settings.py配置数据库

修改默认DATABASES

# DATABASES = {  # 默认数据库sqlite连接
# 'default': {
# 'ENGINE': 'django.db.backends.sqlite3',
# 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
# }
# }
DATABASES={ # mysql连接
'default':{
'ENGINE':'django.db.backends.mysql',
'NAME':'py1', # 数据库名
'USER':'root', # mysql用户名
'PASSWORD':'root', # mysql密码
'PORT':'3306',
}
}

api的创建和调用(Activities:应用,Project1:项目名)

Activities/models.py创建活动表

from django.db import models

# Create your models here.
class activity(models.Model):
# class Meta:
# db_table='activities_activity' id = models.AutoField(primary_key=True)
name = models.CharField(max_length=20)
cost = models.CharField(max_length=20)
deposit = models.CharField(max_length=20)
activity_price_deposit = models.CharField(max_length=20)
toplimit = models.CharField(max_length=20)
Statement = models.CharField(max_length=20)

迁移文件,将models中的表添加到mysql

python manage.py makemigrations  //生成迁移文件
python manage.py migrate //进行迁移

Activities/views.py中创建5个方法的实现

from django.shortcuts import render
from .models import activity
import simplejson
import json from django.http import JsonResponse,HttpResponse,HttpRequest def reg(request:HttpRequest):
return HttpResponse("test") def delete(request:HttpRequest):
try:
payload = simplejson.loads(request.body)
id = payload['id']
mgr = activity.objects.get(id=id)
mgr.delete()
return JsonResponse({'Status': 'DeleteSuccess'})
except Exception as e:
return JsonResponse({'Runstatus': e.args}) def update_by_id(request: HttpRequest):
try:
payload = simplejson.loads(request.body)
id = payload['id']
mgr = activity.objects.filter(id=id)
name = payload['name']
cost = payload['cost']
deposit = payload['deposit']
activity_price_deposit = payload['activity_price_deposit']
toplimit = payload['toplimit']
Statement = payload['Statement']
ac = activity()
ac.id = id
ac.name = name
ac.cost = cost
ac.deposit = deposit
ac.activity_price_deposit = activity_price_deposit
ac.toplimit = toplimit
ac.Statement = Statement
ac.save()
return JsonResponse({'Status': 'UpDateSucess'})
except Exception as e:
return JsonResponse({'Status': 'UpDateError'}) def Select_by_id(request: HttpRequest):
try:
payload = json.loads(request.body)
id = payload['id']
mgr = activity.objects.get(id=id)
data={
'name': mgr.name,
'cost': mgr.cost,
'deposit' : mgr.deposit,
'activity_price_deposit': mgr.activity_price_deposit,
'toplimit': mgr.toplimit,
'Statement': mgr.Statement
}
return JsonResponse(data)
except Exception as e:
return JsonResponse({'Runstatus':e.args}) def Create(request: HttpRequest):
try:
payload = simplejson.loads(request.body)
id = payload['id']
mgr = activity.objects.filter(id=id)
if mgr: # 如果数据库中存在
return JsonResponse({'Status': 'Exist'})
else:
name = payload['name']
cost=payload['cost']
deposit=payload['deposit']
activity_price_deposit=payload['activity_price_deposit']
toplimit=payload['toplimit']
Statement=payload['Statement']
ac = activity()
ac.id = id
ac.name = name
ac.cost=cost
ac.deposit=deposit
ac.activity_price_deposit=activity_price_deposit
ac.toplimit=toplimit
ac.Statement=Statement
ac.save()
return JsonResponse({'Status': 'CreateSucess'}) except Exception as e:
return JsonResponse({'Status': 'CreateError'})

Activities/urls.py中创建子路由(默认无此文件,需自己创建)

from django.conf.urls import url
from .views import reg,delete,Select_by_id,update_by_id,Create
urlpatterns =[
url(r'^reg$',reg),
url(r'^delete$',delete),
url(r'^Select_by_id$',Select_by_id),
url(r'^update_by_id$',update_by_id),
url(r'^Create$',Create),
]

Project1/urls.py中创建路由

urlpatterns = [
url('admin/',admin.site.urls), # 根目录
url(r'^activities/',include('activities.urls')), # 指向子路由
]

一般报错及解决方法

数据库迁移异常

数据库语句无问题时,数据迁移命令无法使用,检查一下mysql的版本

项目下载与使用

百度网盘链接

链接:https://pan.baidu.com/s/1zGAy24ZonOUQJtEo4Zp2-g

提取码:s6wr

测试方式

http://127.0.0.1:8000/admin

账号:admin,密码:adminadmin

发送Reqest请求

http://127.0.0.1:8000/activities/Create

内容包含:

{
"id":"15",
"name":"jack",
"cost":"123",
"deposit":"test",
"activity_price_deposit":"test",
"toplimit":"test",
"Statement":"test"
}

Python-Django WebAPi基本使用方法的更多相关文章

  1. python&django 常见问题及解决方法

    0.python-dev安装(ubuntu) apt-get install  python-dev 1.Open(filename,mode) 报错实例: f = open('d:\Users\16 ...

  2. 使用 Visual Studio Code(VSCode)搭建简单的Python+Django开发环境的方法步骤

    安装配置 VSCode [1]安装 VSCode: 下载地址:https://code.visualstudio.com/ 根据自己电脑对应的操作系统下载对应的版本即可,至于安装过程也和一般的软件一样 ...

  3. python——django使用mysql数据库(二)

    上一篇中,我们已经讲述了如何初始化一个django数据库,这一章就来讲讲在实际的项目中如何使用我们初始化的数据库呢? 如还未进行初始化数据库操作,请参考python——django使用mysql数据库 ...

  4. python Django教程 之 模型(数据库)、自定义Field、数据表更改、QuerySet API

    python  Django教程  之 模型(数据库).自定义Field.数据表更改.QuerySet API 一.Django 模型(数据库) Django 模型是与数据库相关的,与数据库相关的代码 ...

  5. python Django教程 之 安装、基本命令、视图与网站

    python  Django教程  之 安装.基本命令.视图与网站 一.简介 Django 中提供了开发网站经常用到的模块,常见的代码都为你写好了,通过减少重复的代码,Django 使你能够专注于 w ...

  6. python Django 学习笔记(一)—— Django安装

    注:本人python版本2.7.5 ,win7系统 安装Django https://www.djangoproject.com/download/ 官方下载Django-1.5.5.tar.gz 1 ...

  7. python Django知识点总结

    python Django知识点总结 一.Django创建项目: CMD 终端:Django_admin startproject sitename(文件名) 其他常用命令: 其他常用命令: 通过类创 ...

  8. python Django之Form组件

    python Django之Form组件 Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 小试 ...

  9. python Django之Ajax

    python Django之Ajax AJAX,Asynchronous JavaScript and XML (异步的JavaScript和XML),一种创建交互式网页应用的网页开发技术方案. 异步 ...

  10. Python django实现简单的邮件系统发送邮件功能

    Python django实现简单的邮件系统发送邮件功能 本文实例讲述了Python django实现简单的邮件系统发送邮件功能. django邮件系统 Django发送邮件官方中文文档 总结如下: ...

随机推荐

  1. cs244a-Introduction to Computer Networking-Unit2

    Unit2: Transport 学习目标: how TCP set up a connection what TCP segment looks like how can TCP be in hig ...

  2. 解决Asp.Net core 控制台出现乱码的情况

    将控制台的编码页修改成Unicode,在运行程序或者在程序里加一行Console.OutputEncoding = Encoding.Unicode; Console.OutputEncoding = ...

  3. 日语能力考试N2级核心词汇必备—形容词

    日语能力考试N2级核心词汇必备—形容词 ありがたい·有難い 难得的,值得感谢的,真高兴的あかい·赤い 红色的,左翼的,共产主义的あさい·浅い 浅的,事物的程度等小的,色淡的,浅薄的,肤浅的あつい· 1 ...

  4. Nginx进行UDP的负载均衡

    准备工作: 服务器1:192.168.33.102     搭建nginx服务,作为反向代理的中转站 服务器2:192.168.33.103    nginx要反向代理的服务器 一.在服务器1上搭建n ...

  5. tomcat同个端口配置多个项目后无后缀的页面跳转

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  6. Nginx Location规则

    Nginx由内核和模块组成,其中内核的设计非常微小和简洁,完成的工作也非常简单,仅仅通过查找配置文件将客户端的请求映射到一个location block,而location是Nginx配置中的一个指令 ...

  7. laravel 中数据库查询结果自动转数组

    今天在项目中再次碰见laravel中从数据库中查询到的结果是对象,用toArray也不好用,之前改过一次,印象中是在/confing/database.php,    'fetch' => PD ...

  8. 记一次使用dubbo过程中版本冲突导致的坑

    前言:2019年09月23日临下班,产品的一个变更需求临近尾声阶段.本地测试OK,兴致冲冲的想着发布到测试环境,验证一下没有问题,五分钟结束战斗,明天就开始下个需求了.随在CE(公司的devOps系统 ...

  9. 【洛谷P1220】关路灯

    题目有点难描述,内容请直接看原题.. 题解: 可以发现人在关路灯时无论走什么样的路径,从宏观上来看被关的灯总是构成一段包含初始点的连续区间.比如要关掉下标为 l (l < st)的灯,则一定要先 ...

  10. 第二章 psql客户端工具

    第二章 psql客户端工具 pgAdmin是一款功能丰富.开源免费的PostgreSQL图形化工具.psql是PostgreSQL自带的命令行工具,功能全面,是PostgreSQL数据库工程师必须熟练 ...