21. Blog接口开发
一般的系统由登录、增删改查所组成。我们的Blog同样如此。我们会开发登录、创建博客、删除博客、修改博客、查询博客等功能。话不多说,我们直接展开实践吧。
思路分析
- 创建项目。既然我们要创建一个blog,那么我们第一步肯定是创建一个django项目。
- 创建应用。我们上面已经学过,应用是放在django项目中的。
- 设计数据库。我们之前提到过MTV设计模式,其中M我们没有用到。但是在Blog系统中我们将会用到。因为我们会创建博客,所以会有数据存储。
- 编写视图函数V。
- 配置URL。
代码实现
1.创建项目 django-admin blog
2.创建应用 django-admin startproject article,2.blog/settings.py添加article应用,如下代码所示:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'article',
]
3.设计数据库 在article/modles.py输入如下代码:
from django.db import models
# Create your models here.
class Article(models.Model):
title = models.CharField(max_length=10, )
author = models.CharField(max_length=10)
content = models.CharField(max_length=500)
date_publish = models.DateTimeField(auto_now=True)
def __str__(self):
return self.title
备注:__str__的作用是美化打印出来的结果,使人类更方便查看。
4.新建blog数据库 打开wampserver、Navicat,新建blog数据库

5.连接本地数据库 因为我们要使用Navicat连接数据库,所以我们需要对我们的项目进行一些修改,打开settings.py文件,注释粗体部分代码,添加数据库配置代码,如下所示:
# Database
# https://docs.djangoproject.com/en/2.1/ref/settings/#databases
# DATABASES = {
# 'default': {
# 'ENGINE': 'django.db.backends.sqlite3',
# 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
# }
# }
# 新增代码
DATABASES = {
'default':{
'ENGINE': 'django.db.backends.mysql',
'HOST': '127.0.0.1',
'PORT': '3306',
'NAME': 'blog',
'USER': 'root',
'PASSWORD': '',
'OPTIONS': {
'init_command': "SET sql_mode='STRICT_TRANS_TABLES'",
},
}
}
6.在.../blog/init.py 目录下添加:
import pymysql
pymysql.install_as_MySQLdb()
7.数据库迁移 执行python manage.py makemigrations,再执行python manage.py migrate
python manage.py makemigrations
python manage.py migrate
8.创建用户。因为我们接口实现登录的功能,所以我们需要创建用户 。
F:\新建文件夹\blog>python3 manage.py createsuperuser
Username (leave blank to use 'administrator'): admin
Email address: admin@qq.com
Password:
Password (again):
Superuser created successfully.
9.编写视图函数V,打开article/views.py,输入如下代码
from django.http import JsonResponse
from .models import Article
from django.contrib import auth
# 登录接口
def login(request):
if request.method == 'POST':
username = request.POST.get('username', '')
password = request.POST.get('password', '')
if username == '' or password == '':
return JsonResponse({'status': 0, 'message': 'username or password null'})
user = auth.authenticate(username=username, password=password)
if user is not None:
return JsonResponse({'status': 1, 'message': 'login success'})
else:
return JsonResponse({'status': 0, 'message': 'username or password error'})
else:
return JsonResponse({'status': 0, 'message': 'request type error'})
# 添加文章接口
def add_article(request):
if request.method == 'POST':
id = request.POST.get('id', '')
title = request.POST.get('title', '')
author = request.POST.get('author', '')
content = request.POST.get('content', '')
if id == '' or title == '' or author == '' or content == '':
return JsonResponse({'status': 0, 'message': 'id or title or author or content null'})
if len(title) > 10:
return JsonResponse({'status': 0, 'message': '文章标题过长'})
if len(author) > 10:
return JsonResponse({'status': 0, 'message': '作者名称过长'})
if len(content) > 500:
return JsonResponse({'status': 0, 'message': '文章内容过长'})
try:
result = Article.objects.filter(id=id)
except ValueError:
return JsonResponse({'status': 0, 'message': "参数类型错误"})
if result:
return JsonResponse({'status': 0, 'message': 'article id already exists'})
else:
try:
Article.objects.create(id=id, title=title, author=author, content=content)
except BaseException as e:
return JsonResponse({'status': 0, 'message': e})
finally:
data = {
"id": id,
"title": title,
"author": author,
"content": content
}
return JsonResponse({'status': 1, 'data': data, 'message': 'add article success'})
else:
return JsonResponse({'status': 0, 'message': 'request type error'})
# 修改文章接口
def modify_article(request):
if request.method == 'POST':
id = request.POST.get('id', '')
title = request.POST.get('title', '')
author = request.POST.get('author', '')
content = request.POST.get('content', '')
if id == '' or title == '' or author == '' or content == '':
return JsonResponse({'status': 0, 'message': 'id or title or author or content null'})
try:
result = Article.objects.filter(id=id)
except ValueError:
return JsonResponse({'status': 0, 'message': "参数类型错误"})
if not result:
return JsonResponse({'status': 0, 'message': 'article not exist'})
if len(title) > 10:
return JsonResponse({'status': 0, 'message': '文章标题过长'})
if len(author) > 10:
return JsonResponse({'status': 0, 'message': '作者名称过长'})
if len(content) > 500:
return JsonResponse({'status': 0, 'message': '文章内容过长'})
try:
Article.objects.filter(id=id).update(id=id, title=title, author=author, content=content)
except BaseException as e:
return JsonResponse({'status': 0, 'message': e})
finally:
data = {
"id": id,
"title": title,
"author": author,
"content": content
}
return JsonResponse({'status': 1, 'data': data, 'message': 'modify article success'})
else:
return JsonResponse({'status': 0, 'message': 'request type error'})
# 删除文章接口
def delete_article(request):
if request.method == 'POST':
id = request.POST.get('id', '')
if id == '':
return JsonResponse({'status': 0, 'message': 'id null'})
try:
result = Article.objects.filter(id=id)
except ValueError:
return JsonResponse({'status': 0, 'message': "参数类型错误"})
if not result:
return JsonResponse({'status': 0, 'message': 'id not exist'})
try:
Article.objects.filter(id=id).delete()
except BaseException:
return JsonResponse({'status': 0, 'message': '删除文章失败'})
finally:
return JsonResponse({'status': 1, 'message': 'delete article success'})
else:
return JsonResponse({'status': 0, 'message': 'request type error'})
# 查询文章接口
def get_article(request):
if request.method == 'POST':
title = request.POST.get("title", "")
if title == '':
data = []
articles = Article.objects.all()
if articles:
for article in articles:
r = {
"id": article.id,
"title": article.title,
"author": article.author,
"content": article.content
}
data.append(r)
return JsonResponse({'status': 1, 'message': 'success', 'data': data})
if title != '':
data = []
articles = Article.objects.filter(title__contains=title)
if articles:
for article in articles:
r = {
"id": article.id,
"title": article.title,
"author": article.author,
"content": article.content
}
data.append(r)
return JsonResponse({'status': 1, 'message': 'success', 'data': data})
else:
return JsonResponse({'status': 0, 'message': 'query result is empty'})
else:
return JsonResponse({'status': 0, 'message': 'request type error'})
10.配置URL 打开blog/urls.py输入如下代码
from django.contrib import admin
from django.urls import path
from article import views
urlpatterns = [
path('admin/', admin.site.urls),
path('add_article', views.add_article),
path('modify_article', views.modify_article),
path('delete_article', views.delete_article),
path('get_article', views.get_article),
path('login', views.login),
]
11.启动blog 在manage.py同级目录,输入python manage.py runserver
F:\新建文件夹\blog>python manage.py runserver
Performing system checks...
System check identified no issues (0 silenced).
March 04, 2019 - 13:25:31
Django version 2.1.4, using settings 'blog.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.
21. Blog接口开发的更多相关文章
- windows下shopex农行支付接口开发笔记
1.首先是配置Java和tomcat 农行文档里的是linux下的说明.window下我们要按照以下在setclasspath.bat里设置JAVA_HOME,JRE_HOME(红色字体部分).设置这 ...
- 支付宝WAP支付接口开发
支付宝WAP支付接口开发 因项目需要,要增加支付宝手机网站支付功能,找了支付宝的样例代码和接口说明,折腾两天搞定,谨以此文作为这两天摸索的总结.由于公司有自己的支付接口,并不直接使用这个接口,所以晚些 ...
- 详解EBS接口开发之采购申请导入
更多内容可以参考我的博客 详解EBS接口开发之采购订单导入 http://blog.csdn.net/cai_xingyun/article/details/17114697 /*+++++++ ...
- 详解EBS接口开发之库存事务处理批次更新
库存事务处理批次有时候出现导入错误需要更新可使用次程序更新,批次导入可参考博客 详解EBS接口开发之库存事务处理-物料批次导入 http://blog.csdn.net/cai_xingyun/art ...
- 浅谈rest風格的接口开发
简单描述:因为前后端分离,开发完模块之后,接到team leader的指令,我这个渣渣javaer需要给前端人员返回一个接口,具体内容是课程列表json和分类列表json.emmmm,第一次写接口,心 ...
- 基于Axis1.4的webservice接口开发(代码开发)
基于Axis1.4的webservice接口开发(代码开发) 一.开发环境: 我的开发环境是MyEclipse 2015+Apache-Tomcat-8.0.21. 二.代码开发: 1.新建一个Web ...
- 基于Axis1.4的webservice接口开发(环境搭建)
基于Axis1.4的webservice接口开发(环境搭建) 一.环境搭建: 1.搜索关键字“Axis1.4”下载Axis1.4相关的jar包. 下载地址:http://download.csdn.n ...
- 浅谈使用 PHP 进行手机 APP 开发(API 接口开发)
做过 API 的人应该了解,其实开发 API 比开发 WEB 更简洁,但可能逻辑更复杂,因为 API 其实就是数据输出,不用呈现页面,所以也就不存在 MVC(API 只有 M 和 C),那么我们来探讨 ...
- 示例浅谈PHP与手机APP开发,即API接口开发
示例浅谈PHP与手机APP开发,即API接口开发 API(Application Programming Interface,应用程序接口)架构,已经成为目前互联网产品开发中常见的软件架构模式,并且诞 ...
随机推荐
- Shiro那些事儿(一): Shiro初探
引言 权限,可以简单的理解成你能干什么,不能干什么.在管理系统中,对权限的设计可以很简单,也可以很复杂.简单点的,基本都是基于角色扮演的方式,比如系统管理员角色可以操作哪些菜单,普通用户角色可以操作哪 ...
- spring4.1.8扩展实战之二:Aware接口揭秘
Aware.java是个没有定义任何方法的接口,拥有众多子接口,在spring源码中有多处都在使用这些子接口完成各种场景下的回调操作,当业务有需要时,我们只需创建类来实现相关接口,再声明为bean,就 ...
- python 将图片存入mongodb,读取图片,gridfs模块
导入图片引入模块,其中gridfs模块不需要单独安装,引入了pymongo即可直接引入from pymongo import MongoClientfrom gridfs import *import ...
- git 忽略提交及已push过得文件忽略提交
在使用Git的过程中,我们喜欢有的文件比如日志,临时文件,编译的中间文件等不要提交到代码仓库,这时就要设置相应的忽略规则,来忽略这些文件的提交 Git 忽略文件提交的方法 这种方式通过在项目的某个文件 ...
- maven scope 作用域
1.test范围指的是测试范围有效,在编译和打包时都不会使用这个依赖 2.compile范围指的是编译范围有效,在编译和打包时都会将依赖存储进去 3.provided依赖:在编译和测试的过程有效,最后 ...
- JavaScript Set
function Set() { var items = {}; this.has = function(value) { return value in items } this.add = fun ...
- centOS发布.Net Core 2.0 API
1.dotnet xxx.dll & & 放在启动参数后面表示设置此进程为后台进程.(目前测试无效) 2.ps -ef | grep xxx ps:将某个进程显示出来 -A 显示所有 ...
- C++中的面向对象(二)
1,类之间的基本关系: 1,继承: 1,从已存在类细分出来的类和原类之间具有继承关系(is-a): 1,子类就是一个(is-a)父类: 2,继承是单向的: 2,继承的类(子类)拥有原类(父类)的所有属 ...
- WEBRTC三种类型(Mesh、MCU 和 SFU)的多方通信架构
WebRTC 本身提供的是 1 对 1 的通信模型,在 STUN/TURN 的辅助下,如果能实现 NAT 穿越,那么两个浏览器是可以直接进行媒体数据交换的:如果不能实现 NAT 穿越,那么只能通过 T ...
- 43.Word Break(看字符串是否由词典中的单词组成)
Level: Medium 题目描述: Given a non-empty string s and a dictionary wordDict containing a list of non- ...