最后
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
给大家分享一些关于HTML的面试题。
在Flask中,使用werkzeug来做路由分发,werkzeug
是Flask
使用的底层WSGI
库(WSGI,全称 Web Server Gateway interface
,或者 Python Web Server Gateway Interface
,是为 Python 语言定义的Web服务器和Web应用程序之间的一种简单而通用的接口)。
WSGI将Web服务分成两个部分:服务器和应用程序。WGSI服务器只负责与网络相关的两件事:接收浏览器的HTTP请求、向浏览器发送HTTP应答;而对HTTP请求的具体处理逻辑,则通过调用WSGI应用程序进行。WSGI工作流程如下图所示:
在Flask中,路由分发的代码写起来十分简单,如下:
# 管理员注销页面
@main.route('/logout')
def logout():
dm = DataManager()
currentUsers = dm.getUsers('0')
print(currentUsers[0])
return render_template('currentUsers.html', users=currentUsers)
通过业务逻辑函数获得我们所需的数据后,服务器将会根据这些数据来生成HTTP响应(对于Web应用来说,一般就是一个HTML文件,这个是可以直接被我们的客户端,即浏览器直接读取并解释的)。在Web开发中,常规的做法是将获取的数据传入Web应用提供的一个HTML模板文件中,经过模板系统的渲染后最终得到我们所需要的HTML响应文件。
一般情况下,虽然请求不同,但是响应中的数据的展示方式是相同的 ,通俗点说就是除了我们请求获得的数据不一样外,其他都是一样的,那么我们就可以设计一个模板(除了数据内容可以改动,其他都是固定的HTML文件)。我们以博客站点为例,对不同article而言,其具体article content虽然不同,但页面展示的内容除了请求的数据外都是一样的,都有标题拦,内容栏等。也就是说,对于article来说,我们只需提供一个HTML模板,然后传入不同article数据,即可得到不同的HTTP响应。这就是所谓的模板渲染 ,如下图所示:
在Flask中使用Jinja2模板渲染引擎来做模板渲染(Jinja2是基于python的模板引擎,功能比较类似于于PHP的smarty,J2ee的Freemarker和velocity。它能完全支持unicode,并具有集成的沙箱执行环境,应用广泛。jinja2使用BSD授权)。Jinja2的工作流程如下图所示:
在Flask中,模板渲染的代码写起来也是十分的便捷,代码如下:
@app.route('/articles/<int:article\_id>/')
defget_article(article_id):
returnrender_template('path/to/template.html', data_needed)
在Flask
中,我们处理一个请求的流程就是,首先根据用户提交的URL来决定由哪个业务逻辑函数来处理,然后在函数中进行操作,取得所需的数据。再将取得的数据传给相应的模板文件中,由Jinja2负责渲染得到HTTP响应内容,即HTTP响应的HTML文件,然后由Flask返回响应内容。
三、实例项目
下面主要以实例项目对Flask运行原理做一简要解析。在实例项目中,使用到了程序工厂函数和蓝本。项目目录结构如下:
在manager.py文件中,定义了项目启动的入口函数:
# 确保服务器只会在该脚本被 Python 解释器直接执行的时候才会运行,而不是作为模块导入的时候。
if __name__ == '\_\_main\_\_':
# 启用cmd命令行
# manager.run()
app.run(host='0.0.0.0', port=9000, debug=True)
同时,在该文件中创建了工厂方法实例:
app = create_app()
在工程方法中,对数据库进行了相关配置,创建了前端导航栏,同时对所创建的蓝本进行了注册。在创建的蓝本中主要涉及授权、路由及错误处理模块。
# 构造工厂方法
def create\_app():
# 在这里\_\_name\_\_ == \_\_main\_\_
app = Flask(__name__)
app.url_map.converters['regex'] = RegexConverter
# 防止跨站攻击 注:为了增强安全性,密钥不应直接写入代码,而应该保存在环境变量中
# app.config['SECRET\_KEY'] = 'hard to guess string SUNNY2017'
# app.secret\_key = 'Sunny123456'
# flask提供的读取外部文件
app.config.from_pyfile('config')
# basedir = os.path.abspath(os.path.dirname(\_\_file\_\_))
# print(basedir)
# 配置数据库连接
app.config['SQLALCHEMY\_DATABASE\_URI'] = 'mysql+pymysql://lmapp:lmapp@localhost/smp'
app.config['SQLALCHEMY\_COMMIT\_ON\_TEARDOWN'] = True
app.config['SQLALCHEMY\_TRACK\_MODIFICATIONS'] = True
### 最后
**[开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】](https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0)**
**给大家分享一些关于HTML的面试题。**
![](https://img-blog.csdnimg.cn/img_convert/23ac2edf0bcc8989b8b11ddffeeea9c3.webp?x-oss-process=image/format,png)
![](https://img-blog.csdnimg.cn/img_convert/3ef6a5500bedcae4455903518c716092.webp?x-oss-process=image/format,png)
89e65ecb71ac0)**
**给大家分享一些关于HTML的面试题。**
[外链图片转存中...(img-SAHAEZSz-1715428047932)]
[外链图片转存中...(img-cFv2V3cC-1715428047932)]