【发布时间】: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)
【问题讨论】:
-
显示您的完整路线代码!!!!
-
您是否通过此代码从会话中获取
username?session.get('username') -
你使用的是哪个数据库?
-
username = session.get('username') 这就是你获取用户名的方式?
-
我使用的数据库是 SQLite,因为 session.get('username') 它在我的本地机器上工作得很好
标签: python heroku flask flask-sqlalchemy