使用flask遇到的问题及解决方法

flask在客户端接收到的中文显示乱码

解决:

flask版本2.3.0以上:JSON_AS_ASCII 属性被废弃

app = Flask(__name__)
app.json.ensure_ascii = False # 解决中文乱码问题

flask版本2.2.5以下:

app = Flask(__name__)
app.config['JSON_AS_ASCII'] = False  # 解决中文乱码问题

RuntimeError: The current Flask app is not registered with this 'SQLAlchemy' instance. Did you forget to call 'init_app', or did you create multiple 'SQLAlchemy' instances?

使用SQLAlchemy将自定义的model类通过flask写入数据库时遇到上述错误;

解决:

排查启动的客户端程序,在启动的manager.py中,引入了app = Flask(__name__),而在写入数据库中用的db.session(),引用的是之前统一定义的app文件__init__文件的db = SQLAlchemy(app),这样导致声明了两个实例,引发了报错,将manager中的app = Flask(__name__)替换为app的__init__中的db即可。

url中的转义问题

使用flask框架连接数据库,遇到密码中含有特殊字符‘@’,在做url解析时会将密码和host切分错误,导致连接失败;

解决:

对‘@’做url的转义,变为‘%40’ -> 字符的ASCII码(16进制),问题解决;在使用GET等方法发送请求时也会遇到类似问题,可将特殊符号做 url 转义;

%2C:',',%40:'@',%3A:':',%20:space,%5B:'[',%5D:']',%23:'#',%2B: +,%2F:/,%3F:?,%26:&,%3D:=,

启动flask debug模式报错问题

调试flask时使用debug模式启动报错,但正常启动没问题;

解决:设置 app.run(use_reloader=False),关闭热加载即可。

RuntimeError: Working outside of application context.
this typically means that you attempted to use functionality that needed to interface with the current application object in some way. To solve this, set up an application context with app.app_context(). See the documentation for more information

 使用大模型流式输出,向数据库存入对话时,遇到上述报错;

解决:

在存入数据的py函数中添加 with app.app_context():即可,引入的 from app import db, app,要和整个项目保持一致;项目使用SQLAlchemy做数据库管理,引入app和db时要注意保持一致,否则会报错:RuntimeError: Working outside of application context.

def dialogue_add(**param):
    with app.app_context():  # 使用app上下文,在使用模型流式输出时,添加该上下文后才能正常存储到数据库
        session = db.session
        odd = Dialogue(**param)
        session.add(odd)
        session.commit()

使用 sqlalchemy 更新数据库数据时update_time变为0000-00-00

在数据库中设置update_time属性:ALTER TABLE table_name MODIFY update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP;

在数据库中更改属性,update_time会随着更改为当时的时间,而是用sqlalchemy的model更改则出现标题的问题。

解决:

原Model中的设置如下:

update_time = db.Column(db.TIMESTAMP, nullable=True, server_default='CURRENT_TIMESTAMP', onupdate='CURRENT_TIMESTAMP', comment='更新时间')

更改为:

update_time = db.Column(db.TIMESTAMP, nullable=True, server_default=db.func.current_timestamp(), onupdate=db.func.current_timestamp(), comment='更新时间')

参考:

(必解决)新版Flask返回中文乱码解决,unicode编码_python3 flask 中文乱码-CSDN博客

GET请求地址中的URL编码[ %2C,%40... ]字符含义_url %40-CSDN博客

unknown option --port python调试Flask后端报错 Debug mode: on-CSDN博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值