【问题标题】:Flask-Mail Cannot read configurations when config.from_object() is used使用 config.from_object() 时,Flask-Mail 无法读取配置
【发布时间】:2017-12-30 05:41:13
【问题描述】:

我有两个版本的电子邮件发送代码

版本 1(无外部配置文件)

# app.py
from flask import Flask
from flask_mail import Mail, Message

mail = Mail()

app =Flask(__name__)

app.config['MAIL_SERVER']='smtp.gmail.com'
app.config['MAIL_PORT'] = 465
app.config['MAIL_USERNAME'] = 'test@gmail.com'
app.config['MAIL_PASSWORD'] = 'test'
app.config['MAIL_USE_TLS'] = False
app.config['MAIL_USE_SSL'] = True
print(app.config)
mail.init_app(app)

@app.route("/")
def index():
    msg = Message('Hi', sender = 'test@gmail.com', recipients = ['test@gmail.com'])
    msg.body = "Hello"
    mail.send(msg)
    return "Sent"

if __name__ == '__main__':
    app.run(debug = True)

这个版本发邮件没问题

版本 2(使用 from_object() 进行配置)

# app.py
from flask import Flask
from flask_mail import Mail, Message

mail = Mail()

app = Flask(__name__)

app.config.from_object('config.DevelopmentConfig')

# mail = Mail(app)
print(app.config)
mail.init_app(app)

@app.route("/")
def index():
    print('Sending email')
    msg = Message('Tutorial point3', sender = 'test@gmail.com', recipients = ['test@gmail.com'])
    msg.body = "Hello Flask message sent from Flask-Mail "
    mail.send(msg)
    return "Sent"

if __name__ == '__main__':
    app.run()

下面是配置文件

# config.py

class BaseConfig:
    """Base configuration"""
    DEBUG = False
    TESTING = False
    SQLALCHEMY_TRACK_MODIFICATIONS = False
    SECRET_KEY = 'my_precious'
    MAIL_SERVER = 'smtp.gmail.com'
    MAIL_PORT = 465
    MAIL_USE_SSL = True
    MAIL_USE_TLS = False
    MAIL_USERNAME = 'test@google.com'
    MAIL_PASSWORD = 'test'


class DevelopmentConfig(BaseConfig):
    """Development configuration"""
    DEBUG = True

不知何故,第 2 版不起作用并给我这个错误

smtplib.SMTPAuthenticationError: (535, b'5.7.8 Username and Password not accepted. Learn more at\n5.7.8  https://support.google.com/mail/?p=BadCredentials x4sm75923481pfk.51 - gsmtp')

错误消息说我的凭据错误,但我认为这不是真的,因为在版本 1 中我使用完全相同的用户名和密码并且它工作正常。

为了确定我的 config.py 配置是否已加载,我执行了 print(app.config)(尽管我不确定这是否是一个好方法),看起来我的配置已正确加载到我的烧瓶应用程序中。

<Config {'DEBUG': True, 'TESTING': False, 'PROPAGATE_EXCEPTIONS': None, 'PRESERVE_CONTEXT_ON_EXCEPTION': None, 'SECRET_KEY': 'my_precious', 'PERMANENT_SESSION_LIFETIME': datetime.timedelta(31), 'USE_X_SENDFILE': False, 'LOGGER_NAME': '__main__', 'LOGGER_HANDLER_POLICY': 'always', 'SERVER_NAME': None, 'APPLICATION_ROOT': None, 'SESSION_COOKIE_NAME': 'session', 'SESSION_COOKIE_DOMAIN': None, 'SESSION_COOKIE_PATH': None, 'SESSION_COOKIE_HTTPONLY': True, 'SESSION_COOKIE_SECURE': False, 'SESSION_REFRESH_EACH_REQUEST': True, 'MAX_CONTENT_LENGTH': None, 'SEND_FILE_MAX_AGE_DEFAULT': datetime.timedelta(0, 43200), 'TRAP_BAD_REQUEST_ERRORS': False, 'TRAP_HTTP_EXCEPTIONS': False, 'EXPLAIN_TEMPLATE_LOADING': False, 'PREFERRED_URL_SCHEME': 'http', 'JSON_AS_ASCII': True, 'JSON_SORT_KEYS': True, 'JSONIFY_PRETTYPRINT_REGULAR': True, 'JSONIFY_MIMETYPE': 'application/json', 'TEMPLATES_AUTO_RELOAD': None, 'MAIL_PASSWORD': 'test', 'MAIL_PORT': 465, 'MAIL_SERVER': 'smtp.gmail.com', 'MAIL_USERNAME': 'test@google.com', 'MAIL_USE_SSL': True, 'MAIL_USE_TLS': False, 'SQLALCHEMY_TRACK_MODIFICATIONS': False}>

提前感谢您的帮助!

更新1: 修改标题以便更好地理解。 此外,当我测试两个版本时,我使用了实际的 gmail 地址和密码,但在代码 sn-p 中,我将所有凭据替换为“测试”以保护我的帐户

【问题讨论】:

  • 您如何确认版本 1 有效?你真的输入了一个真实的电子邮件地址并收到了一封电子邮件吗?
  • @kshikama 是的,我创建了两个 gmail 帐户,我可以使用我的版本 1 代码发送并在我的另一个 gmail 帐户上接收它。我将我的凭据替换为“测试”以保护我的密码和电子邮件地址。
  • 嗨@ksn。版本 2 中您的电子邮件的域不正确。你的意思是使用gmail.com 而不是google.com
  • @OluwafemiSule 哦,非常感谢。它来自 [这里] (flask.pocoo.org/snippets/85),我没有注意到错字。

标签: python flask web-applications flask-mail


【解决方案1】:

第 2 版中有错字。 我从this flask official snippets复制了代码,所以我希望这个答案可以帮助人们避免落入同样的陷阱。

class BaseConfig:
    """Base configuration"""
    DEBUG = False
    TESTING = False
    SQLALCHEMY_TRACK_MODIFICATIONS = False
    SECRET_KEY = 'my_precious'
    MAIL_SERVER = 'smtp.gmail.com' # <-- Here
    MAIL_PORT = 465
    MAIL_USE_SSL = True
    MAIL_USE_TLS = False
    MAIL_USERNAME = 'test@gmail.com'
    MAIL_PASSWORD = 'test'


class DevelopmentConfig(BaseConfig):
    """Development configuration"""
    DEBUG = True

【讨论】:

    猜你喜欢
    • 2020-02-16
    • 1970-01-01
    • 1970-01-01
    • 2012-07-10
    • 2017-02-19
    • 2014-11-03
    • 2021-12-26
    相关资源
    最近更新 更多