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 import SQLAlchemy

 

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 import Migrate,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;

                    }

              }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小陈工

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值