1,前言
Python的强大,已经涉及到软件开发领域的方方面面。然而,Python入门容易,精确很难,需要深入研究。
在Web方面同样如此,常用的Python Web框架,例如Django、Flask、Tornado等等,共计有100多种,各有优劣。本文以Flask为例,介绍Flask的Restful实现方式,主要实现对数据表的增删查改操作。
2,需求
在开发代码之前,需要提前明确URL请求、HTTP方法与对应的动作。
2.1,Mysql数据表
创建一个简单的数据表,表名是student,存储学生的name、age、birth_time信息。
2.2,学生列表的操作
URL:http://127.0.0.1:5002/student/
get 获取学生列表
post 创建新学生信息
2.3,单个学生的操作
URL:http://127.0.0.1:5002/student/
get 获取单个学生信息
put 更新单个学生信息
delete 删除单个学生信息
2.4,附属功能
要求每次请求之前,记录用户的IP、请求参数等信息,便于统计分析
要求每次数据库操作,判断数据库连接是否正常,避免长时间未进行DB操作而造成DB连接失连
3,Flask项目
3.1,创建Flask项目
Windows可以使用PyCharm安装,或者手动安装
Ubuntu安装flask,执行 sudo apt-get install python-flask
创建hello.py,测试flask是否OK
from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello_world():
return 'Hello World!'
if __name__ == '__main__':
app.run()
启动flask,执行 python hello.py
测试flask,执行 curl http://127.0.0.1:5000/,发现返回“Hello World!”,证明安装成功
如果返回缺少某些python包,莫急,逐个安装即可
3.2,目录规划
按照MVC的思想,对控制层和视图层进行分离。控制层主要是对数据库的处理,可以按照不同的数据表进行分文件处理;视图层,按照不同的功能模块,进行份文件处理。这样,便于项目维护和模块扩展。
不过,一定还有更好的目录规划方式,因项目或团队不同而不同,适合自己的即是最好的。
下面是初步划分的文件目录,可以参考。
D:\PYTEST\FLASK_TEST
│ ctrl_student.py # 视图层,响应URL请求
│ db_student.py # 控制层,数据库处理
│ flask_test.py # Flask主文件,控制URL路由
│ test.py # 测试文件
├─static
└─templates
4,源码
4.1,数据库表
student表结构
CREATE TABLE `student` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(255) DEFAULT NULL,
`age` int(11) DEFAULT NULL,
`birth_time` datetime DEFAULT NULL,
`cre