flask框架实战5-全局对象g和连接数据库

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>

--参考
https://zhuanlan.zhihu.com/p/104273184

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容