记踩坑--Flask Web开发:第六章的电子邮件 ----[Errno 11004] getaddrinfo failed

必须要记录下踩过的坑,一来,为后来者铺路,二来,实在摔得疼,提醒自己写代码要谨小慎微。

[Errno 11004] getaddrinfo failed

1.先排除邮箱账号和授权码的错误

测试如下代码:(注:邮箱号和授权码换成你自己的)

# -*- coding: utf-8 -*-

from flask import Flask
from flask_mail import Mail, Message

app = Flask(__name__)

app.config[‘MAIL_SERVER‘] = ‘smtp.qq.com‘  # 邮件服务器地址
app.config[‘MAIL_PORT‘] = 25  # 邮件服务器端口
app.config[‘MAIL_USE_TLS‘] = True  # 启用 TLS
app.config[‘MAIL_USERNAME‘] = ‘[email protected]‘
app.config[‘MAIL_PASSWORD‘] = ‘nxvxvzbbbbbbbcec‘

mail = Mail(app)

@app.route(‘/‘)
def index():
    msg = Message(‘恭喜!排除授权码和账号的问题!‘, sender=‘[email protected]‘, recipients=[‘[email protected]‘])
    msg.html = ‘<b>Hello Web</b>‘
    mail.send(msg)
    return ‘<h1>OK!</h1>‘

if __name__ == ‘__main__‘:
    app.run(host=‘127.0.0.1‘, debug=True)

2.再排查环境变量是否设置正确

打开你当前文件的虚拟环境,设置如下代码

(venv) $ set MAIL_USERNAME = [email protected]
(venv) $ set MAIL_PASSWORD = password

 注意::环境变量配置中不加引号!!不加引号!!不加引号!!

程序中看是否成功get到

print(os.environ.get(‘MAIL_USERNAME‘))
print(os.environ.get(‘MAIL_PASSWORD‘))

能get到后,就可以在程序中获取环境变量的配置啦!

app.config[‘MAIL_USERNAME‘] = os.environ.get(‘MAIL_USERNAME‘) 

app.config[‘MAIL_PASSWORD‘] = os.environ.get(‘MAIL_PASSWORD‘) 

3.在程序中集成发送电子邮件功能

import os
from flask import Flask, render_template, session, url_for, redirect
from flask_bootstrap import Bootstrap
from flask_wtf import FlaskForm
from wtforms import StringField, SubmitField
from wtforms.validators import DataRequired
from flask_sqlalchemy import SQLAlchemy
from flask_script import Manager
from flask_script import Shell
from flask_migrate import Migrate, MigrateCommand
from flask_mail import Mail, Message

basedir = os.path.abspath(os.path.dirname(__file__))

app = Flask(__name__)
app.config[‘SECRET_KEY‘] = ‘hard to guess string‘
app.config[‘SQLALCHEMY_DATABASE_URI‘] =     ‘sqlite:///‘ + os.path.join(basedir, ‘data.sqlite‘)
app.config[‘SQLALCHEMY_COMMMIT_ON_TEARDOWN‘] = True
app.config[‘SQLALCHEMY_TRACK_MODIFICATIONS‘] = True

app.config[‘MAIL_SERVER‘] = ‘smtp.qq.com‘
app.config[‘MAIL_PORT‘] = 25
app.config[‘MAIL_USE_TLS‘] = True
app.config[‘MAIL_USERNAME‘] = os.environ.get(‘MAIL_USERNAME‘)
print(os.environ.get(‘MAIL_USERNAME‘))
app.config[‘MAIL_PASSWORD‘] = os.environ.get(‘MAIL_PASSWORD‘)
print(os.environ.get(‘MAIL_PASSWORD‘))
app.config[‘FLASKY_MAIL_SUBJECT_PREFIX‘] = ‘[Flasky]‘
app.config[‘FLASKY_MAIL_SENDER‘] = ‘[email protected]‘  # 发送者邮箱
app.config[‘FLASKY_ADMIN‘] = os.environ.get(‘FLASKY_ADMIN‘)  # 接收者邮箱
print(os.environ.get(‘FLASKY_ADMIN‘))

bootstrap = Bootstrap(app)
db = SQLAlchemy(app)
manager = Manager(app)
migrate = Migrate(app, db)
mail = Mail(app)

class NameForm(FlaskForm):
    name = StringField(‘What is your name?‘, validators=[DataRequired()])
    submit = SubmitField(‘Submit‘)

class Role(db.Model):
    __tablename__ = ‘roles‘
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(64), unique=True)
    users = db.relationship(‘User‘, backref=‘role‘, lazy=‘dynamic‘)

    def __repr__(self):
        return ‘<Role: %s>‘ % self.name

class User(db.Model):
    __tablename__ = ‘users‘
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(64), unique=True, index=True)
    role_id = db.Column(db.Integer, db.ForeignKey(‘roles.id‘))

    def __repr__(self):
        return ‘<User: %s>‘ % self.username

def send_email(to, subject, template, **kwargs):
    msg = Message(app.config[‘FLASKY_MAIL_SUBJECT_PREFIX‘] + ‘ ‘ + subject,
                  sender=app.config[‘FLASKY_MAIL_SENDER‘], recipients=[to])
    msg.body = render_template(template + ‘.txt‘, **kwargs)
    msg.html = render_template(template + ‘.html‘, **kwargs)
    mail.send(msg)

def make_shell_context():
    return dict(app=app, db=db, User=User, Role=Role)

manager.add_command(‘shell‘, Shell(make_context=make_shell_context))  # 集成python shell
manager.add_command(‘db‘, MigrateCommand)  # 创建数据库迁移

@app.route(‘/‘, methods=[‘GET‘, ‘POST‘])
def index():
    form = NameForm()

    if form.validate_on_submit():
        user = User.query.filter_by(username=form.name.data).first()
        if user is None:
            new_user = User(username=form.name.data)
            db.session.add(new_user)
            db.session.commit()
            session[‘known‘] = False  # 新用户(数据库中没查到你)
            if app.config[‘FLASKY_ADMIN‘]:
                send_email(app.config[‘FLASKY_ADMIN‘], ‘New User‘,
                           ‘mail/new_user‘, user=new_user)
        else:
            session[‘known‘] = True  # 老用户
        session[‘name‘] = form.name.data
        form.name.data = ‘‘
        return redirect(url_for(‘index‘))
    return render_template(‘index.html‘, form=form, name=session.get(‘name‘),
                           known=session.get(‘known‘, False))

@app.route(‘/user/<name>‘)
def user(name):
    return render_template(‘user.html‘, name=name)

@app.errorhandler(404)
def page_not_found(e):
    return render_template(‘404.html‘), 404

@app.errorhandler(500)
def internal_server_error(e):
    return render_template(‘500.html‘), 500

if __name__ == ‘__main__‘:
    # manager.run()
    app.run(host=‘127.0.0.1‘, port=5200, debug=True)

4. 创建模板

new_user.html:

User {{ user.username }} has joined.

new_user.txt:

User <b>{{ user.username }}</b> has joined.

  

5. 跑起来

(env) C:\Users\Administrator\PycharmProjects\lagou\jokertion_blog>python hello.py shell

注意:记得先在虚拟环境(venv)中设置好三个环境变量:

set [email protected]

set MAIL_PASSWORD=xxxxxxxxxxxxxx

set [email protected]

  

6.大功告成!新增功能:新添用户,自动发送邮件提醒管理员。

原文地址:https://www.cnblogs.com/liangmingshen/p/10162153.html

时间: 2024-08-29 10:23:24

记踩坑--Flask Web开发:第六章的电子邮件 ----[Errno 11004] getaddrinfo failed的相关文章

《Flask Web开发 基于Python的Web应用开发实战》简评

指路牌 <Flask Web开发><Flask Web开发 基于Python的Web应用开发实战><Flask Web开发>是否适合新手入门Python Web开发? 正文 <Flask Web开发 基于Python的Web应用开发实战>,O'Reilly"动物书系列"的"狗书",应该是很多Flask初学者被推荐使用的入门书,但是这本书真的适合初学者吗? Python的Web框架非常多,例如Django.Flask.T

Flask web开发----使用mysql数据库

根据<flask web开发>书中说不建议在生产环境中使用SQLite,所以在我跟着书本敲完api这一章的代码时,准备将数据库改用成mysql 1.现将这俩个文件删除,因为这是之前使用的SQLite数据库相关的文件 2.将原项目中的config文件中数据库的地址修改为如图所示的Mysql数据库.你需要现在你本机电脑上安装Mysql数据库,而且你存在一个用户的账户为:root,密码为:root,创建的数据库名称为Flask.(这里对mysql不做过多的讲解) 出于安全考虑可以将路径通过 (ven

flask web开发笔记 -- 快速入门

flask web开发笔记 -- 快速入门 初始化 Flask应用需要创建应用实例. Web服务器通过Web Server Gateway Interface (WSGI)协议把从客户端接收到的请求传递给该对象.应用程序实例是Flask类对象,通常创建如下: from flask import Flask app = Flask(__name__) Flask类的构造函数唯一的参数是应用的主模块名或包名,用于确定应用的根目录.对于大多数应用程序,使用Python的__name__变量即可. 路由

flask web开发笔记 -- 表单 --待整理

虽然Flask的请求对象给表单处理提供了足够的支持,但也有一些任务繁琐和重复.比如为表单生成HTML代码和验证提交表单数据. Flask-WTF扩展能解决上述问题.它基于wtforms 防止跨站请求伪造 跨站请求伪造(Cross-site request forgery),也被称为 one-click attack 或者 session riding,通常缩写为 CSRF 或者 XSRF, 是一种挟制用户在当前已登录的Web应用程序上执行非本意的操作的攻击方法.跟跨网站脚本(XSS)相比,XSS

Flask之旅《Flask Web开发:基于Python的Web应用开发实战》学习笔记

<Flask Web开发:基于Python的Web应用开发实战> 点击上方的"目录"快速到达哦! 虽然简单的网站(Flask+Python+SAE)已经上线,但只是入门.开发大型网站,系统地学习一遍还是有必要的. 1 虚拟环境 2016-6-8 书上介绍了 virtualenv,每个venv都会拷贝一份packages到项目 /venv目录. virtualenv venv venv\Scripts\activate.bat (venv) $ pip freeze >

flask web开发笔记 -- 数据库

关系数据库基于关系,有主键.外键等.它存储数据高效,避免了重复:修改数据方便.缺点是连接的成本过高. NoSQL尽量避免连接,但是增加了数据冗余,修改数据麻烦,不过查询快速. 对于中小型的应用,两者的效率差别不大. python数据库框架 Flask对数据库没有限制,你可以使用MySQL, Postgres, SQLite, Redis, MongoDB或CouchDB等.另外还有数据抽象层SQLAlchemy和MongoEngine等. 选择数据库时需要关注: 易用性:抽象层,比如ORM(ob

《Flask Web开发——基于Python的Web应用开发实践》一字一句上机实践(下)

目录 前言 第8章 用户认证 第9章 用户角色 第10章 用户资料 第11章 博客文章 第12章 关注者 第13章 用户评论 第14章 应用编程接口   前言 第1章-第7章学习实践记录请参见:<Flask Web开发——基于Python的Web应用开发实践>一字一句上机实践(上) 本文记录自己学习<Flask Web开发——基于Python的Web应用开发实践>的第8章-第14章内容.相比于刚开始学习第1-7章内容来说,本部分内容实战性更强,而且在书本上遇到的问题也相对较少,如果

《Flask Web开发:基于Python的Web应用开发实战》pdf 免费下载

<Flask Web开发:基于Python的Web应用开发实战>pdf 免费下载链接: https://u253469.ctfile.com/fs/253469-292665036 第一部分 Flask 简介第1 章 安装 .........................................................................................................................................

《Flask Web开发:基于Python的Web应用开发实战》pdf 完整版免费下载

<Flask Web开发:基于Python的Web应用开发实战>.pdf pdf 完整版免费下载: https://u253469.ctfile.com/fs/253469-292665036 更多电子书下载: http://hadoopall.com/book 内容简介 本书不仅适合初级Web开发人员学习阅读,更是Python程序员用来学习高级Web开发技术的优秀参考书. ? 学习Flask应用的基本结构,编写示例应用: ? 使用必备的组件,包括模板.数据库.Web表单和电子邮件支持: ?