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)