1. 公用变量存储使用
在web开发时涉及变量和数据的使用是非常复杂的。对于页面之间的共同需要使用的变量,可以使用缓存技术保存在浏览器中,也可以在服务器端存储到数据库里后面再取用。例如对于有些网站需要保存用户登录状态,或者临时存储部分数据,除了采用session会话、cookie等缓存技术外,flask框架也提供了处理上下文的方式全局g对象和context处理。
g对象使用起来较为简单,直接赋予其属性即可。如g.name、g.attrs等。
from flask import g
g.name='cr'
在当前页面请求中就可以直接使用g的值了。
context上下文处理可以在局部也可以在全局。
例如想定义一下全局公用变量,可以采用如下方式:
@app.context_processor
def common():
isLogin=False
return isLogin
这样代码中的isLogin变量就会在项目业务中通用。
2. flask与数据库连接,实现新闻读取
上述表单的处理已经涉及到了一些动态交互处理技术,不过因为讨论表单的处理方式,所以没有涉及数据库的操作。由于main.py实际上就是一个服务器上的后端处理程序,后端就可能会与数据库链接来实现数据的持久性存储和查询读取。
鉴于python中自带sqlite轻量型数据库,我们在这里直接使用即可。前面也有文章讨论过在python中来操作数据库,链接为:https://zhuanlan.zhihu.com/p/91075748
我们可以直接使用其中的方法来实现本案例,不过还需要结合flask框架来实施。
首先在web2020项目文件夹下新建一个dbutil.py文件,专门用于处理数据库相关业务。然后在代码窗口将增删改查业务代码编写好,这里直接参考上述的链接代码:
class dbUtils:
def __init__(self, dbName): # 连接数据库
import sqlite3
self.conn = sqlite3.connect(dbName)
def db_action(self, sql, actionType=0): # 进行相关业务操作
try:
res = self.conn.execute(sql)
if actionType == 1: # 当操作类型为1时代表为查询业务,返回查询列表
return res.fetchall()
else: # 当操作类型不为1时代表为新增、删除或更新业务,返回逻辑值
return True
except ValueError as e:
print(e)
def close(self): # 关闭数据库
self.conn.commit()
self.conn.close()
#1.创建数据库
db=dbUtils('web2020.db')
#2.创建新闻表
sql='create table news (newsid int, content text, author text)'
if db.db_action(sql,0)==True:
print("创建新闻表成功!")
else: print("try again1")
#3.新增新闻
sql= "insert into news values(1,'武汉疫情非常严重,口罩等急需物品短缺','cao')," \
"(2,'全国人民都给武汉加油,疫情肯定会控制住','cao')"
if db.db_action(sql,0)==True:
print("新增新闻表成功!")
else: print("try again1")
db.close()
执行后,就完成了新闻表的创建,同时新增了两条新闻。
接下来在main.py文件中修改一下newspage方法,用于读取数据库中的两条新闻,并显示在新闻页面中。
@app.route('/news')
def newspage():
import dbutil #导入dbutil模块,就是上面这个文件
db=dbutil.dbUtils('web2020.db') #链接web2020数据库
sql='select * from news' #组装查询sql语句
newslist=db.db_action(sql,1) #查询处理并返回列表
db.close() #关闭数据库
return render_template("news.html",data=newslist) #将数据传递到news.html页面中
然后在news.html页面中使用jinjia2模板中的语法来读取两条新闻内容:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>news</title>
</head>
<body>
<p>今日新闻</p>
{% for item in data %} #采用循环来读取列表中的内容
<p style="color:red">{{item}}</p>
{% endfor %}
<hr>
<p><a href="/ ">回到首页</a></p>
<p> <a href="{{ url_for('productpage',a=50) }}">去看产品页</a></p>
</body>
</html>