从 RDS 检索数据给出 AttributeError: 'sqlalchemy.cimmutabledict.immutabledict' object has no attribute 'setdefault' 错误堆栈跟踪当前包版本我试图解决的问题有关我的应用程序设置的更多信息

如何解决从 RDS 检索数据给出 AttributeError: 'sqlalchemy.cimmutabledict.immutabledict' object has no attribute 'setdefault' 错误堆栈跟踪当前包版本我试图解决的问题有关我的应用程序设置的更多信息

每当调用 API 端点 {{url}}/api/users/login用户进行身份验证时,我都想从 RDS 检索用户数据,但是,我目前在从 RDS 检索数据时遇到问题。

错误堆栈跟踪

这是错误的完整堆栈跟踪:

enter image description here

当前包版本

Flask==1.1.2
Flask-Cors==3.0.10
flask-marshmallow==0.14.0
Flask-Migrate==2.5.3
Flask-RESTful==0.3.8
Flask-sqlAlchemy==2.4.4
marshmallow==3.10.0
marshmallow-sqlalchemy==0.24.1
sqlAlchemy==1.4.0b1
python==3.7

我试图解决的问题

我尝试解决问题但无济于事的一些事情是:

  • 使用 pyMysqL 连接器代替 MysqLconnector
  • 降级烧瓶棉花糖==0.11.0
  • 降级棉花糖==3.6.1
  • 降级棉花糖-sqlalchemy==0.23.1

有关我的应用程序设置的更多信息

我已经对我的应用程序进行了 Docker 化,这是我当前的设置:

app.py

from flask_marshmallow import Marshmallow
from flask_migrate import Migrate
from flask_sqlalchemy import sqlAlchemy
from flask_jwt_extended import JWTManager

db = sqlAlchemy()
ma = Marshmallow()
migrate = Migrate()

def register_extensions(app: Flask) -> None:
   db.init_app(app)
   migrate.init_app(app,db)
   ma.init_app(app)

def create_application() -> Flask:
   app: Flask = Flask(__name__)
   app.config['sqlALCHEMY_DATABASE_URI'] = "MysqL+MysqLconnector://{DB_USER}:{DB_PASSWORD}@{DB_INSTANCE}:{DB_PORT}"
   app.config['sqlALCHEMY_TRACK_MODIFICATIONS'] = False
   register_extensions(app)
   app.register_blueprint(users_urls.mod,url_prefix=f"/{BEP_PREFIX}/users")

   return app

 app = create_application()
 CORS(app)

models.py

class Accounts(db.Model):
    __tablename__ = 'Accounts'
    username = db.Column(db.String(100),primary_key=True)
    password = db.Column(db.String(256),nullable=False)
    email = db.Column(db.String(255),nullable=False)
    personnelID = db.Column(db.String(255),nullable=False)
    userType = db.Column(db.String(45),nullable=False)

service.py

class UserService(Service):
    __model__ = Accounts

    def get(self,username):
        return Accounts.query.filter_by(username=username).first()

user_service = UserService()

views.py

from bep.users.services import user_service

class UserLogin(Resource):
   def post(self):
       data = request.get_json()

       try:
           userData = user_service.get("test")
       except Exception:
           error_str = traceback.format_exc()
           logger.error("This prints the stack",exc_info=True)
           return UserServiceError.to_response(error=error_str,comments="Something went wrong while logging in") 

解决方法

问题是flask-sqlalchemy 中的known issue,由SQLAchemy 1.4 中的更改引起。 Flask-sqlalchemy 尝试修改 SQLALchemy 引擎的 URL,但这些 URL 在 SQLAlchemy 1.4 中是不可变的。

该问题已在 Flask-SQLAlchemy 2.5+ (changelog) 中修复。

如果无法升级 Flask-SQLAlchemy,可以通过指定传递给 pip 的 SQLAlchemy 版本来解决该问题,或者通过命令行

pip install --upgrade 'SQLAlchemy<1.4'

或在 requirements.txt

SQLAlchemy<1.4

SQLAlchemy 1.4 于 2021 年 3 月 15 日正式发布。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?