Vue的Python flask框架后台,使用SQLite
前言
Python真的是一种非常容易上手的语言,有一定基础的人随便看看了解一下基本语法就可以做出东西,它能最快速地帮你实现脑子里千奇百怪的想法(
有很多奇奇怪怪的人开发了很多奇奇怪怪的轮子),而我也是之前要做一个有趣的东西才会了解flask框架。这篇文章主要是针对我的Vue博客所开发出的后台写的,很简单,就提供了基本的接口,还有一些对数据库的操作。
安装flask
安装python我就不说了,网上有很多教程,python3自带pip工具,我们用它来先安装一个虚拟的python运行环境(每个项目都有一个,防止不同项目所需依赖不同造成冲突),再在虚拟环境中安装flask,参考贼良心的flask中文文档,but,我选择pycharm无脑新建flask项目。
flask路由
下面是一个路由的基本形式
@app.route("/title", methods=['GET', ])
def function():
......
但我们的博客有很多文章,我想要一个路由就能访问所有文章,那么我们就要用到动态路由了(对应前端Vue发起请求也是用到了动态路由),如下代码:
@app.route("/articles/<name>", methods=['GET', ])
def functin(name):
......
<>内的name是可变的,如果你访问http://127.0.0.1:5000/articles/3,那么3就会作为一个参数传进function,即执行function("3")
ps:
- 动态路由传参是传字符串
- http://127.0.0.1:5000/是默认地址,可在app.run()里设置
Python操作SQLite,markdown转换html
动态路由传入name来搜索指定文章
先上python代码:
@app.route("/articles/<name>", methods=['GET', ])
def markdownToHtml(name):
import sqlite3
# 连接到SQLite数据库
# 数据库文件是test.db
# 如果文件不存在,会自动在当前目录创建:
conn = sqlite3.connect('test.db')
# 创建一个光标Cursor:
cursor = conn.cursor()
#从数据库获取文章
cursor.execute("SELECT article FROM articles where id=?;", (name))
text = cursor.fetchone()
#把从数据库获取的list格式的文章连接成字符串格式
text = "".join(text)
#markdown格式的text转换成html
html = markdown(text)
# 关闭Cursor:
cursor.close()
# 提交事务:
conn.commit()
# 关闭Connection:
conn.close()
return html
加一个
SQLite可视化工具SQLiteStudio了解一下