SMTPServerDisconnected: пожалуйста, сначала запустите connect ()

#python #flask #flask-security #flask-mail

#python #flask #flask-безопасность #flask-mail

Вопрос:

Я изучаю flask и пытаюсь настроить простое веб-приложение с безопасной регистрацией и входом. Для этого я использую flask-security. К сожалению, когда я перехожу на страницу подтверждения отправки, я получаю сообщение об ошибке: «smtpserverdisconnected: пожалуйста, сначала запустите connect ()».

Ниже приведены соответствующие файлы, которые я написал. run.py управляет всем приложением.

run.py (это находится рядом с app папкой)

 #!venv/bin/python
from app import app
app.run(debug = True)
  

Все, что приведено ниже, находится в app папке

__init__.py

 from flask import Flask
from flask.ext.mail import Mail
from flask.ext.sqlalchemy import SQLAlchemy

app = Flask(__name__)
app.config.from_object('config')

db = SQLAlchemy(app)
mail = Mail(app)

import models
import views

@app.before_first_request
def create_user():
    db.create_all()
    models.user_datastore.create_user(email = 'user@example.com',
            password = 'password')
    db.session.commit()

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

models.py

 from app import db, app
from flask.ext.sqlalchemy import SQLAlchemy
from flask.ext.security import SQLAlchemyUserDatastore,
        UserMixin, RoleMixin, Security

roles_users = db.Table('roles_users',
        db.Column('user_id', db.Integer(), db.ForeignKey('user.id')),
        db.Column('role_id', db.Integer(), db.ForeignKey('role.id')))

class Role(db.Model, RoleMixin):
    id = db.Column(db.Integer(), primary_key = True)
    name = db.Column(db.String(80), unique = True)
    description = db.Column(db.String(255))

class User(db.Model, UserMixin):
    id = db.Column(db.Integer, primary_key = True)
    email = db.Column(db.String(255), unique = True)
    password = db.Column(db.String(255))
    active = db.Column(db.Boolean())
    confirmed_at = db.Column(db.DateTime())
    roles = db.relationship('Role', secondary = roles_users,
            backref = db.backref('users', lazy = 'dynamic'))

user_datastore = SQLAlchemyUserDatastore(db, User, Role)
security = Security(app, user_datastore)
  

views.py

 from app import app
from flask import render_template
from flask.ext.security import login_required

@app.route('/')
@login_required
def index():
    return render_template('index.html')
  

редактировать: кроме того, вот файл конфигурации, который я использую

 DEBUG      = True
SECRET_KEY = 'secret'
SQLALCHEMY_DATABASE_URI = 'sqlite://'

SECURITY_PASSWORD_HASH = 'sha512_crypt'
SECURITY_PASSWORD_SALT = 'salt'
SECURITY_CONFIRMABLE = True
SECURITY_REGISTERABLE = True
SECURITY_RECOVERABLE = True
SECURITY_TRACKABLE = True
SECURITY_CHANGEABLE = True

MAIL_SERVER = 'smtp.zoho.com'
MAIL_PORT = 465
MAIL_USE_TLS = False
MAIL_USE_SSL = True
MAIL_DEBUG = True
MAIL_USERNAME = 'myaddress@mydomain'
MAIL_PASSWORD = 'password'
  

Ответ №1:

Хорошо, итак, я понял, в чем проблема. По умолчанию flask-security настроен на отправку почты как «localhost». Мой почтовый провайдер — Zoho, но я просто использую их в качестве почтового сервера для домена, который я запускаю. Мои настройки почты таковы, что я могу отправлять почту только с определенных адресов. Поскольку ‘localhost’ не является одним из этих flask-security не удалось подключиться к серверам Zoho.

Итак, решение состояло в том, чтобы добавить в мой конфигурационный файл строку

 SECURITY_EMAIL_SENDER = 'valid_email@my_domain.com'
  

Надеюсь, это сэкономит кому-то еще некоторое время, пытаясь выяснить, почему электронная почта flask-security не работает.

Комментарии:

1. Да, это сэкономило мне некоторое время, жаль, что исходное сообщение об ошибке не стало немного понятнее. Поскольку я установил MAIL_DEFAULT_SENDER, это даже не приходило мне в голову.