flask框架(四)配套代码

时间:2022-06-26
本文章向大家介绍flask框架(四)配套代码,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

demo01blueprint.py

"""
蓝图基本使用[掌握]

- 作用: 为了进行模块化开发
- 特点: 属于flask中自带的,不需要安装扩展就能使用
- 蓝图的使用流程:
  - 1.创建蓝图对象
  - 2.使用蓝图装饰视图函数
  - 3.将蓝图注册到app中

"""
from flask import Flask,Blueprint
from demo02product import blue
from demo03user import user_blue

app = Flask(__name__)

#3.将蓝图注册到app中
app.register_blueprint(blue)
app.register_blueprint(user_blue)


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

demo02product.py

from flask import Blueprint

#1.创建蓝图对象
blue = Blueprint("my_blue",__name__)


#2.使用蓝图装饰视图函数
#首页
@blue.route('/')
def index():

    return 'index'

#列表页
@blue.route('/list')
def list():

    return 'list'

#详情页
@blue.route('/detail')
def detail():

    return 'detail'

#还有其他的很多的视图函数
#.....

demo03user.py

from flask import Blueprint

#1.创建蓝图对象
user_blue = Blueprint("user",__name__)

#2.使用蓝图装饰视图函数
@user_blue.route('/user_info')
def user_info():

    return "user_Info"

以包的形式使用蓝图

各个文件的关系

demo04package_Blueprint.py

from flask import Flask
from user import user_blue

app = Flask(__name__)

#3.注册蓝图到app中
app.register_blueprint(user_blue)


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

user包的__init__.py

from flask import  Blueprint

#1.创建蓝图对象
#参数1: user,表示蓝图的名字,用来标识蓝图装饰的视图函数所属的蓝图
#参数2: __name__,固定写法,表示的是蓝图所在包的名字
#参数3: static_folder,用来存储静态文件的
#参数4: url_prefix,给所有使用user_blue装饰的视图函数都加上一个访问前缀
#参数5: template_folder,表示蓝图自己的模板文件, 如果app中也设置也自己的模板,如果文件名相同,那么优先访问app的
user_blue = Blueprint("user",__name__,static_folder="static",url_prefix="/user",template_folder="templates")
print(__name__)

#导入views文件
from user import views

user包的views.py

from flask import render_template

from user import user_blue

#2.装饰视图函数
@user_blue.route('/user_login')
def user_login():

    return "user_login"


#渲染模板
@user_blue.route('/register')
def register():

    return render_template("file02user.html")

user包的templates文件夹的file02user.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .box{
            width: 300px;
            height: 300px;
            background: yellow;
        }

    </style>
</head>
<body>

    <div class="box">
        我是一个孤独的div
    </div>

</body>
</html>

user包的static文件夹下的haha.jpg

断言:demo05assert.py

def division_number(num1,num2):

    #判断num1,num2必须要整数
    assert isinstance(num1,int),"num1必须是一个整数"
    assert isinstance(num2,int),"num2必须是一个整数,并且不为0"

    return num1/num2


# print(division_number(10,5))
# print(division_number("10",5))
print(division_number(10,"5"))

demo06unittest.py

"""
- 1.定义类,继承自unittest.TestCase
    继承自TestCase的类,可以直接单独运行
- 2.编写两个固定方法
  - setup: 测试开始的方法
  - teardown: 测试结束的方法
- 3.编写自己的测试方法
  - 必须以test开头
    光标放在哪个函数的内部,就执行哪个测试方法

"""
import unittest
class MyTest(unittest.TestCase):

    def setUp(self):
        print("setup")

    def test_login(self):
        print("test_login")

    def test_login2(self):
        print("test_login2")


    def tearDown(self):
        print("teardown")

demo07databasetest.py

"""
目的: 数据库添加数据是否正常
"""
from unittest import TestCase
from demo07library import app,db,Author,Book
#1.定义类,继承自TestCase
class DatabaseTest(TestCase):

    #2.编写两个固定方法setup,teardown
    def setUp(self):
        #设置数据库的链接信息
        app.config["SQLALCHEMY_DATABASE_URI"] = "mysql+pymysql://root:123456@127.0.0.1:3306/library36_test"

        #创建数据库
        db.create_all()

    def tearDown(self):
        db.session.remove()
        db.drop_all()

    #3.编写添加数据的测试方法
    def test_db_addData(self):

        #3.1创建作者对象
        author = Author(name="laowang")

        #3.2添加数据到数据库中
        db.session.add(author)
        db.session.commit()

        import time
        time.sleep(10)

        #3.3查询数据
        author2 = Author.query.filter(Author.name == "laowang").first()

        #3.4断言
        self.assertIsNotNone(author2, "取出来的作者2一定不是空")
        self.assertEqual(author.name,author2.name,"两个对象中的名字必须要一样")

demo08redis.py

"""
IDE操作string[掌握]

- 操作流程:
  - 1.安装扩展包
    - pip install redis
  - 2.导入redis类
    - from redis import StrictRedis
  - 3.创建redis对象,关联ip,port
  - 4.调用今天学习的redis相关的方法

"""
# 2.导入redis类
from redis import StrictRedis

# 3.创建redis对象,关联ip,port,decode_responses将redis取出来的数据自动解码
redis_store = StrictRedis(host="127.0.0.1",port=6379,decode_responses=True)

# 4.调用今天学习的redis相关的方法
#增加数据,还可以设置有效期
#参数1: name,表示key
#参数2: banzhang,表示value
#参数3: 100, 表示key-value的有效期,单位是秒
redis_store.set("name","banzhang",100)

#修改数据
redis_store.set("name","laowang",100)

#获取数据
name = redis_store.get("name")
# print(name.decode())
print(name)

#删除数据
redis_store.delete("name")

demo09flask_session.py

"""
19_session指定存储位置

- 定义: 用来存储敏感信息,存储在服务器内部
- 设置: session[key] = value
- 获取: value = session.get(key)
- 注意点: 设置SECRET_KEY
- 指定session存储到redis中
- 操作流程:
  - 1.安装flask_session
    - pip install flask_session
  - 2.导入Session类
    - from flask_sessiion import Session
  - 3.设置session相关的配置信息到app中
  - 4.读取app身上的配置信息(和session相关的)
    - Session(app)

"""
from datetime import timedelta

from flask import Flask,session
from flask_session import Session
from redis import StrictRedis

app = Flask(__name__)

#设置app的配置信息
# app.config["SECRET_KEY"] = "fdfdfdfd"
# app.config["SESSION_TYPE"] = "redis" #指定session的存储类型
# app.config["SESSION_REDIS"] = StrictRedis() #指定redis服务器的地址
# app.config["SESSION_USE_SIGNER"] = True #设置session的签名信息
# app.config["PERMANENT_SESSION_LIFETIME"] = timedelta(seconds=10) #设置session在redis中的存储时间

#读取配置类,加载配置信息到app中
class Config(object):
    SECRET_KEY = "fdfdfdfd"
    SESSION_TYPE = "redis"
    SESSION_REDIS = StrictRedis()
    SESSION_USE_SIGNER = True
    PERMANENT_SESSION_LIFETIME = timedelta(seconds=10)

app.config.from_object(Config)


#读取app中关于session的配置信息
Session(app)

@app.route('/set_session')
def set_session():

    session["name"] = "laowang"

    return "set_session"

@app.route('/get_session')
def get_session():

    value = session.get("name")

    return "name is %s"%value

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