Python-Django WebAPi基本使用方法
目的
利用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基本使用方法的更多相关文章
- python&django 常见问题及解决方法
0.python-dev安装(ubuntu) apt-get install python-dev 1.Open(filename,mode) 报错实例: f = open('d:\Users\16 ...
- 使用 Visual Studio Code(VSCode)搭建简单的Python+Django开发环境的方法步骤
安装配置 VSCode [1]安装 VSCode: 下载地址:https://code.visualstudio.com/ 根据自己电脑对应的操作系统下载对应的版本即可,至于安装过程也和一般的软件一样 ...
- python——django使用mysql数据库(二)
上一篇中,我们已经讲述了如何初始化一个django数据库,这一章就来讲讲在实际的项目中如何使用我们初始化的数据库呢? 如还未进行初始化数据库操作,请参考python——django使用mysql数据库 ...
- python Django教程 之 模型(数据库)、自定义Field、数据表更改、QuerySet API
python Django教程 之 模型(数据库).自定义Field.数据表更改.QuerySet API 一.Django 模型(数据库) Django 模型是与数据库相关的,与数据库相关的代码 ...
- python Django教程 之 安装、基本命令、视图与网站
python Django教程 之 安装.基本命令.视图与网站 一.简介 Django 中提供了开发网站经常用到的模块,常见的代码都为你写好了,通过减少重复的代码,Django 使你能够专注于 w ...
- python Django 学习笔记(一)—— Django安装
注:本人python版本2.7.5 ,win7系统 安装Django https://www.djangoproject.com/download/ 官方下载Django-1.5.5.tar.gz 1 ...
- python Django知识点总结
python Django知识点总结 一.Django创建项目: CMD 终端:Django_admin startproject sitename(文件名) 其他常用命令: 其他常用命令: 通过类创 ...
- python Django之Form组件
python Django之Form组件 Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 小试 ...
- python Django之Ajax
python Django之Ajax AJAX,Asynchronous JavaScript and XML (异步的JavaScript和XML),一种创建交互式网页应用的网页开发技术方案. 异步 ...
- Python django实现简单的邮件系统发送邮件功能
Python django实现简单的邮件系统发送邮件功能 本文实例讲述了Python django实现简单的邮件系统发送邮件功能. django邮件系统 Django发送邮件官方中文文档 总结如下: ...
随机推荐
- node.js使用swig模块
1.安装swig npm install swig --save 2.创建app.js文件 /*应用程序入口文件*/ /*加载express模块*/ var express = require('ex ...
- eclipse经常弹出Subversion Native Library Not Available解决方案
- clientXxx与offsetXxx与scrollXxx区别
1.clientXxx与offsetXxx与scrollXxx 1.clientXxx: clientWidth = width+padding(left+right) clientHeight = ...
- 优化 JS 条件语句及JS 数组常用方法, ---- 看完绝对对日后开发有用
前言: 日常所说的优化优化.最后我们到底优化了哪些,不如让我们从代码质量开始:个人觉得简洁简化代码其实觉得存在感挺强烈的QAQ 1. 获取URL中 ?后的携带参数: 这是我见过最简洁的了,若有更简洁的 ...
- Linux上安装ElasticSearch及遇到的问题
在Linux上安装ElasticSearch 1. 安装前环境准备 安装JDK环境,并配置环境变量,这里可以参考我以前写过的博客 https://www.cnblogs.com/ywb-article ...
- Scala Nothing 从官方DOC翻译
Nothing is - together with scala.Null - at the bottom of Scala's type hierarchy. Scala中的Nothing和Null ...
- Ubuntu18.04 安装redis
Redis是常用基于内存的Key-Value数据库,比Memcache更先进,支持多种数据结构,高效,快速.用Redis可以很轻松解决高并发的数据访问问题:作为实时监控信号处理也非常不错. 安装red ...
- 关于myBatis配置中的一些注意事项
最近在学习mybatis,在网上查阅资料,并按照别人的范例来测试,总会出一些错误,这里把配置过程中的一些注意事项梳理一下. 一.导包(用eclipse开发) 1.如果你新建的是普通的project,需 ...
- - Power Strings (字符串哈希) (KMP)
https://www.cnblogs.com/widsom/p/8058358.htm (详细解释) //#include<bits/stdc++.h> #include<vect ...
- Codeforces 989 P循环节01构造 ABCD连通块构造 思维对云遮月参考系坐标轴转换
A 直接判存不存在连续的三个包含A,B,C就行 /*Huyyt*/ #include<bits/stdc++.h> #define mem(a,b) memset(a,b,sizeof(a ...