【问题标题】:Heroku Internal Server Error 500: 'NoneType' object has no attribute 'username'Heroku 内部服务器错误 500:“NoneType”对象没有属性“用户名”
【发布时间】:2019-11-29 09:46:37
【问题描述】:

尝试在 Heroku 上部署我的 Flask 应用程序时返回以下错误:

2019-11-29T09:07:28.456446+00:00 app[web.1]: File "/app/saltchat.py", line 55, in chatRoom
2019-11-29T09:07:28.456448+00:00 app[web.1]: onlineUsers.append(user.username)
2019-11-29T09:07:28.456454+00:00 app[web.1]: AttributeError: 'NoneType' object has no attribute 'username'
2019-11-29T09:07:28.458151+00:00 app[web.1]: 10.183.68.6 - - [29/Nov/2019:09:07:28 +0000] "GET /chat HTTP/1.1" 500 290 "https://salt-chat-v2.herokuapp.com/login" "Mozilla/5.0 (Windows NT 10
.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.108 Safari/537.36"

当我在本地机器上部署应用程序时,它按预期工作,并且仅在通过 /chat 路由时遇到问题:

@app.route('/chat', methods=['POST', 'GET'])
def chatRoom():
    username = session.get('username')
    user = Users.query.filter_by(username=username).first()
    if request.referrer is None:
        return render_template('login.html')
    else:
        onlineUsers.append(user.username)
        onlineUserAvatars.append(user.avatar)
        return render_template('chat.html')

下面是我使用的数据库模型:

class Users(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(32), nullable=False)
    password = db.Column(db.String, nullable=False)
    avatar = db.Column(db.Integer)

【问题讨论】:

  • 显示您的完整路线代码!!!!
  • 您是否通过此代码从会话中获取usernamesession.get('username')
  • 你使用的是哪个数据库?
  • username = session.get('username') 这就是你获取用户名的方式?
  • 我使用的数据库是 SQLite,因为 session.get('username') 它在我的本地机器上工作得很好

标签: python heroku flask flask-sqlalchemy


【解决方案1】:

我认为问题出在您的会话用户上。 请修改您的代码如下:

@app.route('/chat', methods=['POST', 'GET'])
def chatRoom():
    username = session.get('username', '')
    try:  
        user = Users.query.filter_by(username=username).first()
    except:
        print("Something wrong")
    if request.referrer is None:
        return render_template('login.html')
    else:
        onlineUsers.append(user.username)
        onlineUserAvatars.append(user.avatar)
        return render_template('chat.html')

【讨论】:

  • 好吧,这很奇怪,因为我尝试使用您的代码更改每个 session.get('username') ,它只工作一次,但在我以新用户身份登录后,它对任何人都不起作用之后至少在 Heroku 上的其他实例(它在本地机器上工作)
  • 你是如何从 heroku 使用/访问数据库的?
  • SQLite 我使用 db.create_all() 来初始化数据库
  • @CorvusRex,这可能不是你的直接问题,而是you can't use SQLite on Heroku
  • 我刚注意到这个问题并决定使用另一个数据库。谢谢@Chris
猜你喜欢
  • 2021-12-03
  • 1970-01-01
  • 2021-04-12
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-03-30
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多