flask面试题 冲冲冲
如何改变Flask的默认地址和端口
在应用程序上调用run方法时,可以通过将修改的值传递给主机和端口参数来更改Flask的默认主机和端口。
使用Flask框架有什么好处
1、 它具有内置的开发服务器。
2、 它具有大量的第三方扩展。
3、 它具有一个很小的API,并且可以由Web开发人员快速学习。
4、 它符合WSGI。
5、 它支持Unicode。
SQLite数据库是否内置Flask
1、SQLite是Python内置的。
2、要在Flask中使用数据库,我们不需要安装任何其他的Flask-Extension。
3、在视图内部,我们可以导入SQLite并编写SQL查询以与数据库进行交互。
4、Flask开发人员通常使用Flask-SQLAlchemy,它消除了编写复杂SQL查询的需要,并且支持与SQLite数据库进行交互的ORM。
Flask框架中的模板引擎是什么意思
1、模板是一个包含两种类型的数据的文件,即静态和动态,在运行期间填充模板中的动态数据。
2、Flask利用Jinja2模板引擎,使开发人员可以使用带有占位符的HTML模板来创建动态数据。
3、通过使用Flask的render_template方法以及所需的参数和值,可以在运行时填充这些占位符。
Django和Flask有什么区别?为什么要选择Flask
1、Django是一个使用Python编程语言创建的Web开发框架。
2、它是功能齐全的Web应用程序框架,具有许多内置功能,例如Admin后端和具有迁移功能的ORM。
3、它创建时间早,更成熟。
4、Flask适用于快速开发用例。
5、Flask更适合开发不需要大型代码库的轻量级Web应用程序。它易于开发微服务或无服务器应用程序。
5、与Django相比,Flask简单易学且API更少。
6、随着行业追随将微服务作为容器的一部分的趋势,将Flask保留在您的Web开发工具包中很实用
Flask中的g对象是什么?它与会话对象有何不同
1、Flask的g对象用作全局命名空间,用于在应用程序上下文中保存任何数据。
2、g对象不适用于在请求之间存储数据。从某种意义上说,字母g代表global。
3、在某些情况下,当您需要在应用程序上下文中保留全局变量,而不是创建全局变量时,最好使用g对象,因为Flask中的每个请求都有一个单独的g对象。
4、Flask的g对象使我们免于意外修改自定义全局变量。
您可以通过哪些方式连接Flask中的数据库
1、Flask可用于大多数RDB模式,例如PostgreSQL,SQLite和MySQL。
2、要连接数据库,我们必须使用Flask-SQLAlchemy扩展。它使开发过程中的数据库交互和管理变得容易,而无需编写原始SQL查询。
3、原始SQL查询容易受到SQL注入攻击。对于使用NoSQL数据存储(例如MongoDB),我们可以使用Flask-MongoEngine扩展
Flask蓝图的作用
蓝图Blueprint实现模块化的应用
book_bp = Blueprint(‘book’, name)创建蓝图对象
蓝图中使用路由@book_bp.route(‘url’)
在另一.py文件里导入和注册蓝图
from book import book_bp
app.register_blueprint(book_bp)
作用:
1、将不同的功能模块化
2、构建大型应用
3、优化项目结构
4、增强可读性,易于维护(跟Django的view功能相似)
Flask框架默认session处理机制
1、Flask的默认session利用了Werkzeug的SecureCookie,把信息做序列化(pickle)后编码(base64),放到cookie里了。
2、过期时间是通过cookie的过期时间实现的。
3、为了防止cookie内容被篡改,session会自动打上一个叫session的hash串,这个串是经过session内容、SECRET_KEY计算出来的,看得出,这种设计虽然不能保证session里的内容不泄露,但至少防止了不被篡改
列举HTTP请求中的状态码
404 请求的url地址不存在
503 访问限制有权限
200 访问成功
302 重定向
1xx —— 元数据
2xx —— 正确的响应
3xx —— 重定向
4xx —— 客户端错误
5xx —— 服务端错误
100 Continue。客户端应当继续发送请求。
200 OK。请求已成功,请求所希望的响应头或数据体将随此响应返回。
201 Created。请求成功,并且服务器创建了新的资源。
301 Moved Permanently。请求的网页已永久移动到新位置。 服务器返回此响应(对GET或HEAD请求的响应)时,会自动将请求者转到新位置。
302 Found。服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。
400 Bad Request。服务器不理解请求的语法。
401 Unauthorized。请求要求身份验证。对于需要登录的网页,服务器可能返回此响应。
403 Forbidden。服务器拒绝请求。
404 Not Found。服务器找不到请求的网页。
500 Internal Server Error。服务器遇到错误,无法完成请求。
Flask-WTF是什么?有什么特点?
1、Flask-wtf是一个用于表单处理,校验并提供csrf验证的功能的扩展库
2、Flask-wtf能把正表单免受CSRF<跨站请求伪造>的攻击
3、Flask-WTF 提供 FileField 来处理文件上传,它在表单提交后,自动从 flask.request.files 中抽取数据。FileField 的 data 属性是一个
SQLAlchemy如何执行原生SQL
两种SQLAlchemy可以执行原生sql的方式
第一种是通过session(会话)对象执行execute方法
session = scoped_session(SessionFactory)
session.execute(‘insert users(name) values(:value)’, params={‘value’: ‘thanlon’})
第二种是通过cursor(游标)对象执行execute方法。
conn = engine.raw_connection()
cursor = conn.cursor()
cursor.execute(‘select * from users’)
DBUtils模块的作用
作用:
DBUtils模块的作用是实现数据库连接池,是为了解决“多线程情况下请求比较多时性能降低”的问题