当前位置:
首页
文章
数据库
详情

Flask教程(二)

一、Flask的数据库SQLAlchemy

1.1 SQLAlchemy简介:

                SQLAlchemy是一个关系型数据库框架,它提供了高层的ORM和底层的原生数据库的操作。

                flask-sqlalchemy是一个简化了SQLAlchemy操作的flask扩展。

1.2 SQLAlchemy的使用:

1.2.1安装导入:    安装flask_sqlalchemy

                            from flask import Flask

from flask_sqlalchemy importSQLAlchemy

1.2.2创建flask的app:

                            app = Flask(__name__)

1.2.3配置SQLAlchemy参数:

                            class Config(object):

                            """配置参数"""

                            # sqlalchemy的配置参数

                            SQLALCHEMY_DATABASE_URI= "mysql://root:mysql@127.0.0.1:3306/db_python04"

数据库类型://用户名:密码@数据库地址:端口号/数据库名

                            # 设置sqlalchemy自动更跟踪数据库

                            SQLALCHEMY_TRACK_MODIFICATIONS= True

1.2.4添加配置到app:

                            app.config.from_object(Config)

1.2.5创建数据库sqlalchemy工具对象:

db = SQLAlchemy(app)

1.2.6定义数据库表:

                            class Role(db.Model):

                            """用户角色/身份表"""

__tablename__ = "tbl_roles"        #表名

id = db.Column(db.Integer, primary_key=True)    #表的主键

                                    name = db.Column(db.String(32), unique=True)

                                    users = db.relationship("User", backref="role")

                                    def __repr__(self):

                                    """定义之后,可以让显示对象的时候更直观"""

                                            return "Role object: name=%s" % self.name

1.2.7启动函数执行的命令:

                            if __name__ == '__main__':

                                    # 清除数据库里的所有数据

                                    db.drop_all()

                                    # 创建所有的表

                                    db.create_all()

                                    # 创建对象

                                    role1 = Role(name="admin")

                                    # session记录对象任务

db.session.add(role1)

                                    # 提交任务到数据库中

db.session.commit()

二、数据库迁移

2.1首先要在虚拟环境中安装Flask-Migrate:

pip install flask-migrate

2.2导入相关文件:

                from flask_migrate importMigrate,MigrateCommand

from flask_script import Shell,Manager

2.3使用Manager管理我们创建的app:

                app = Flask(__name__)

manager = Manager(app)

2.4配置数据库参数,同上1.2.3

2.5使用migrate将配置的数据库与app关联起来:

#第一个参数是Flask的实例,第二个参数是Sqlalchemy数据库实例

migrate = Migrate(app,db)

2.6在flask-Script中的manager中添加一个db命令:

manager.add_command('db',MigrateCommand)

2.7定义模型类,同上1.2.6

2.8运行管理器:

                if __name__ == '__main__':

manager.run()

2.9创建迁移仓库,在命令行输入:

                #这个命令会创建migrations文件夹,所有迁移文件都放在里面。

 python code.py db init

2.10创建迁移脚本,同Django类似,有两个命令:

                #创建自动迁移脚本

                python code.py db migrate-m 'initial migration'  #后面为脚本的备注

                #更新数据库

                python code.py db upgrade

三、发送邮件

3.1Flask框架使用Flask-Mail扩展包实现发送邮件功能

3.2使用QQ邮箱的smtp服务器:

3.3在代码中导入Flask-Mail扩展包:

from flask_mail import Mail, Message

3.4配置发送邮件需要的参数:

#配置邮件:服务器/端口/传输层安全协议/邮箱名/密码

                    app.config.update(

                                DEBUG = True,

                                MAIL_SERVER='smtp.qq.com',

                                MAIL_PROT=465,

                                MAIL_USE_TLS = True,

                                MAIL_USERNAME = '371673381@qq.com',

                                MAIL_PASSWORD = 'goyubxohbtzfbidd',

                      )

3.5关联app:

                    mail = Mail(app)

3.6在视图函数中的处理:

# sender 发送方,recipients 接收方列表

                msg = Message("This is a test ",sender='371673381@qq.com', recipients=                                                              ['371673381@qq.com'])

#邮件内容

                msg.body = "Flask test mail"

                #发送邮件

                mail.send(msg)

四、Flask中的蓝图

4.1蓝图简介:蓝图是用于实现单个应用的视图、模板、静态文件的集合

4.2蓝图的初始化:

                    #Blueprint必须指定两个参数,admin表示蓝图的名称,__name__表示蓝图所在模块

admin = Blueprint('admin',__name__)

4.3注册蓝图路由:

@admin.route('/')

                    def admin_index():

                                return 'admin_index'

4.4在程序实例中注册该蓝图:

app.register_blueprint(admin,url_prefix='/admin')

五、单元测试

5.1单元测试的意义:

Web程序开发过程一般包括以下几个阶段:[需求分析,设计阶段,实现阶段,测试阶段]。其中测试阶段通过人工或自动来运行测试某个系统的功能。目的是检验其是否满足需求,并得出特定的结果,以达到弄清楚预期结果和实际结果之间的差别的最终目的。

5.2测试的分类:单元测试、集成测试、系统测试等,其中单元测试是由开发人员进行的

5.3单元测试的方法:开发者编写一小段代码,检验目标代码的功能是否符合预期。通常情况下,单元测试主要面向一些功能单一的模块进行。

5.4单元测试中断言(assert)的使用:

5.4.1常用的断言方法:

                assertEqual     如果两个值相等,则pass

                assertNotEqual  如果两个值不相等,则pass

                assertTrue      判断bool值为True,则pass

                assertFalse     判断bool值为False,则pass

                assertIsNone    不存在,则pass

                assertIsNotNone 存在,则pass

5.5单元测试的基本写法:

5.5.1定义一个类,继承自unittest.TestCase:

                import unittest

 class TestClass(unitest.TestCase):

                        #该方法会首先执行,方法名为固定写法

def setUp(self):

                                pass

                        #测试代码,函数命名格式一定以test_开头

def test_app_exists(self):

                                pass

                        #该方法会在测试代码执行完后执行,方法名为固定写法

def tearDown(self):

                                pass

六、Flask的部署

6.1Flask部署示意图:

6.2由上图可以看出,Flask部署主要方式是Nginx+gunicorn+flask

其中Gunicorn(绿色独角兽)是一个Python WSGI的HTTP服务器,

优点是Gunicorn直接用命令启动,不需要编写配置文件,相对uWSGI要容易很多。

6.3Gunicorn的安装:pip install gunicorn

6.4运行Gunicorn

#指定进程和端口号: -w: 表示进程(worker)-b:表示绑定ip地址和端口号(bind)。

$gunicorn -w 4 -b 127.0.0.1:5001 运行文件名称:Flask程序实例名

6.5安装Nginx:$sudo apt-get install nginx

6.6nginx的相关指令:先进入/usr/local/nginx/目录

                #启动

sudo sbin/nginx

                #查看

ps aux | grep nginx

                #停止

sudo sbin/nginx -s stop

6.7修改nginx配置:打开/usr/local/nginx/conf/nginx.conf文件

            server {

                    # 监听80端口

                    listen 80;

                    # 本机

                    server_name localhost;

                    # 默认请求的url

                   location /{

                            #请求转发到gunicorn服务器

proxy_pass http://127.0.0.1:5001;

                            #设置请求头,并将头信息传递给服务器端

                            proxy_set_header Host $host;

                    }

              }

免责申明:本站发布的内容(图片、视频和文字)以转载和分享为主,文章观点不代表本站立场,如涉及侵权请联系站长邮箱:xbc-online@qq.com进行反馈,一经查实,将立刻删除涉嫌侵权内容。