flask基础1

Flask六行代码运行

# 六行启动Flask 提供HelloWorld
from flask import Flask  # 导入Flask 类创建Flask应用对象
app = Flask(__name__)  # app = application

@app.route("/index")  # 为 Flask 应用对象增加路由
def index():  # 与路由绑定的视图函数 视图函数名尽可能保持唯一 
    return "HelloWorld"  # “” 相当于 Django 中的 HttpResponse

if __name__ == '__main__':  # 当前文件处于脚本状态时运行如下代码
    app.run()  # 启动Flask 应用

Flask 中的 Response

常用返回值

1.HTTPResponse("HelloWorld")       "HelloWorld"
2.render("html文件")            render_template("HTML文件") # 默认存放路径是"templates"
# 文件html黄色 解决步骤 右键templats->Mark Directory as->Templates Folder Template Languages更改默认语言为jinjia2
3.redirect("/home")                redirect("/home")
# ResponseHeaders 中加入了一个 Localtion:http://url 为重定向位置

 

特殊返回值

# Flask 特殊返回值
4.send_file("文件路径")         返回文件
# 打开并返回文件内容 自动识别文件类型 在ResponseHeaders中加入
# Content-Type:文件类型 - *文件类型 是可以被客户端识别的文件类型
# 不能识别的类型 下载处理 - 浏览器会下载
###### x-ms x二进制 ms微软 wma文件

5.jsonify("字符串或数据类型")     返回标准格式的JSON字符串
# Content-Type:application/json == 标准格式
# Flask 1.1.1
# return d  # 暂时不建议使用 兼容性
# 直接返回dict时 本质上在执行jsonify(d)
# API 接口 AJAX.post({username:123}){
function(data){ obj = data }}
# 1.打包JSON 序列化JSON字符串
# 2.编写ResponseHeaders 加入 Content-Type:application/json

# 利用 Flask 做一个登录 username password 
# request?

 

Flask 中的 Request

methods=["GET","POST"] 在添加路由的装饰器中允许请求方式,覆盖
1.request.form 获取FormData中的数据 to_dict() ImmutableMultiDict
2.request.method 获取请求方式
3.request.args  # 获取URL中的数据 字符串 get("key") to_dict()

GET
# 在Django request.GET 取出 URL 中的参数
# 在Flask 获取URL 中的参数
# print(request.url) # 请求地址
# print(request.url_charset) # URL 编码方式
# print(request.url_root) # 请求地址 完整请求地址 host
# print(request.url_rule) # 请求路由地址
# print(request.values.to_dict())  # 接收所有(GET,POST)请求中的数据,包含了 URL 和 FormData 中的数据
# print(request.args.get("id"))  # 获取URL中的数据 字符串

POST
# 在Django request.POST 取出 FormData (Form表单)
# 在Flask 获取FormData request.form
# print(request.form.get("username"))
# print(request.form.to_dict())

获取一个 FileStorage Flask文件特殊对象
# print(request.files.get("my_file")) "获取文件名my_file的文件"
# my_file = request.files.get("my_file")
# new_file = os.path.join("xht",my_file.filename) "xht文件下,拼接原文件名"
# my_file.save(new_file)   "保存文件,重命名"

获取其他数据
# request.headers
# request.cookies
# request.path == request.url_rule
# request.host == "127.0.0.1:9527"
# request.host_url == "http://127.0.0.1:9527/"

特殊提交方式数据获取
# Content-Type:application/json
# request.json 获取Content-Type:application/json时提交的数据
# Content-Type 无法被识别 或 不包含Form字眼
# request.data 获取 原始请求体中的数据 b""

 

 

Flask中的CBV

内置方法

http_method_funcs = frozenset(
["get", "post", "head", "options", "delete", "put", "trace", "patch"]
)

from flask import views 导入CBV的视图基类

class Login(views.MethodView): # 继承CBV视图基类的最高类
    def get(self):
        return "GET 200 OK!"
    def post(self):
        return "POST 200 OK!"

CBV添加路由

app.add_url_rule("/login",view_func=Login.as_view(name="login"))

 

 

 

Flask中的Session

from flask import session
app = Flask(__name__)  # __name__
app.secret_key = "!@#$%^&*()" # 开启秘钥

sesion正常流程

session 服务器端的键值对
cookie 客户端的键值对
交由客户端保管机制

1.开启session[username] = 123
  {
    username=123
  }
2.序列化字典 == 字符串
3.加密字符串 SecreKey 秘钥字符串

接收反序列化Session
1.从Cookie中获取到一个叫 Session key 的值
2.通过SecreKey的值
3.反序列化成字典

交由客户端保管机制

1.session["user"] = "123"
2.序列化session 字符串
3.通过 SECRET_KEY 加密字符串 加密算法
4.cookie中加入 {SESSION_COOKIE_NAME}:SECRET_KEY 加密字符串
5.返回客户端

反:
1.Cookie获取{SESSION_COOKIE_NAME}:SECRET_KEY
2.通过 SECRET_KEY 解密 字符串 解密算法
3.反序列化 字符串 字典 - session
4.session.get("user")

 

 

Flask开启Debug

app.debug=True

 

 

 

Windows配置debug

# 在terminal中
set FLASK_ENV=development
flask run

 

Jinja2

{{}}     #引用变量数据 执行函数
{%%}   # 逻辑代码

 

路由

 

@app.route("/")
def index():

*endpoint app中是唯一的 路由和视图函数之间的桥梁
*methods 允许请求的方式 ["GET","POST","DELETE","PUT"]
**动态参数路由
"/index/<page>"
"/look/<xiaojiejie>/<picture>"
def look(xiaojiejie,picture):

defaults = {nid:1} # 视图的默认参数
strict_slashes # 是否严格遵循路由匹配规则 "/结尾/" True False
redirect_to # 永久重定向 301 308

app.add_url_rule()

app.add_url_rule('/name',view_func=函数名)

 

from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello_world():
    print(1, session.get("user"))
    return 'Hello World!'

 

传参<>

@app.route('/me/<user>')
def me(user):
    return '个人'+user

数字类型

@app.route('/me/<int:user>')
def me(user):
    return '个人'+str(user)

 

 

 

url_for

在Flask开发中总会遇到一些坑,下面是自己踩到的关于url_for()的坑 

url_for()函数是用于构建指定函数的URL。反向解析路由

url_for操作对象是函数,而不是route里的路径。

 

如果route和函数名不一样而导致使用url_for()错误,千万不要去route找错误。 
例如下面的代码:

https://www.cnblogs.com/liuxiaowei/p/9039622.html

# 参数
url_for('.static',_external=True,filename='pic/test.png')
endpoint 
URL的端点(即函数的名字)
values 
URL的变量参数
_external 
如果设置为True,则生成一个绝对路径URL
_scheme 
一个字符串指定所需的URL方案。_external参数必须设置为True,不然会抛出ValueError。
_anchor 
如果设置了这个则给URL添加一个mao
_method 
如果设置这个则显示地调用这个HTTP方法

 

methods

允许请求的方式 ["GET","POST","DELETE","PUT"]

redirect_to

永久重定向 没有进入视图直接跳转 redirect_to="/new_look"

strict_slashes=False

是否严格要求 路由匹配规则 "/last/"

defaults={"nid":"22"}

默认参数 def 视图函数中(nid)一定要接受参数

 

初始化

app = Flask(__name__)
template_folder # 模板存放路径 os.path.join(root_path,template_folder)
static_folder # 静态文件存放路径
static_url_path # 静态文件访问路径 "/{static_folder}"
    
import_name # __name__ 锁定当前文件的目录 保证文件唯一
root_path # 当前application的所在目录 由import_name自动创建
host_matching # 主机位 匹配 config.server_name
static_host # 远程静态文件服务 "{static_host}/{static_folder}"
subdomain_matching # 支持子域名的主机位匹配
instance_path # 另一个Flask示例导入
instance_relative_config # 另一个FlaskConfig导入

 

 

 

配置文件

创建配置文件settings放入配置信息

在run文件,导入 

from flask import Flask
app = Flask(__name__)
import settings
app.config.from_object(settings) # 把settings当成对象加载进来


app.config.from_object(settings)   # 传入settings对象
app.config.from_pyfile(settings.py)   # 传入settings.py文件
 
app.default_config 默认配置
DEBUG 模式 开启编辑时代码重启 Log打印级别最低 错误信息透传
TESTING 模式 无限接近生产环境 代码编辑不会重启 Log级别较高 错误信息不再透传
SESSION_COOKIE_NAME 存放在浏览器cookie中session的名称
SESSION_COOKIE_HTTPONLY 是否只在HTTP请求下开启 session
JSONIFY_MIMETYPE 更改 jsonify 时的 Content-Type

app.config["SESSION_COOKIE_NAME"] = "I am Not Session" 第一个字符,绝对不能是 空格 

Flask Config 快速配置

class DebugConfig:
    DEBUG = True
    SECRET_KEY = "%^&*(%^&*"
    PERMANENT_SESSION_LIFETIME = 3600
    SESSION_COOKIE_NAME = "I am Not Session"
    OLD = "OLD"
    BOY = "BOY"
    EDU = "EDU"
    PYTHON = "PYTHON"
    FLASK = "FLASK"

app.config.from_object(DebugConfig)

config = {k:v}
config[k1] = v1
{k:v,k1:v1}

 

 Flask 初始化实例化参数

 

*static_folder         静态文件存放路径
*static_url_path     静态文件访问路径 默认值为 "/{static_folder}"
*template_folder    模板存放路径
static_host 静态文件访问服务HOST -> 指向到另外一台服务器

 

 

Flask 中的 蓝图 Blueprint

Django app01
蓝图作用 功能隔离 路由隔离

蓝图就是不能Run的Flask示例
蓝图中没有Config对象
蓝图的作用 隔离应用 隔离路由
bp = Blueprint("蓝图名称全Flask示例唯一",__name__)
@bp.route("application路由一致",url_prefix="/url前缀")
from flask import Blueprint
# Blueprint 当做一个不能够run的Flask 实例
user = Blueprint(name="app02user",__name__,url_prefix="/shopping") # url_prefix
@user.route("/login")
def login():
    return "I am app02 userBP login func"    
    
在Flask实例中增加注册蓝图
app.regiest_blueprint(蓝图-user)

name="app02user" 蓝图名称 不能重复 保证在app中是唯一的
url_prefix="/shopping" URL前缀 用于隔离相同URL

 

Flask特殊装饰器

@app.before_request 请求进入视图函数之前
@app.after_request 请求结束,返回影响客户端之前
    
正常 be1 - be2 - be3 - vf - af3 - af2 - af1
异常 be1 - be2 - af3 - af2 - af1
    
@app.errorhandler(4xx or 5xx) 重定义错误信息
@app.errorhandler(404)
    def error404(ErrorMessage):
        print(ErrorMessage)
        return redirect("https://www.autohome.com.cn/beijing/asdfe32r24rff23r23r")
        # return send_file("image/1.jpg")

 

端口监听流程

"0.0.0.0" 5000
"192.168.14.26" 5000
端口 - 应用程序
包 -> 应用程序

IOS 5层中的最高层
应用                     -                                     应用
浏览器-9528        目的:(b"HTTP 1.1 / GET\r\n")            192.168.14.26:9527

服务器接收字符串 b"HTTP 1.1 / GET\r\n"
网卡 b"HTTP 1.1 / GET\r\n" - 操作系统 我这里有一段数据你看看吧
操作系统 解包 - 端口 9527 应用程序 - 9527 这个数据包你看看
WSGI:9527 - 收到 b"HTTP 1.1 / GET\r\n" 
Flask - WSGI 帮我把这些数据转换成 对象 environ ,这个对象可以 打点儿调用属性
Flask 收到 WSGI 转换的 environ对象 request_class Flask Request 样式
Django request.POST 
Flask request.form 

 

g对象和session的区别

session对象是可以跨request的,只要session还未失效,不同的request的请求会获取到同一个session,但是g对象不是,g对象不需要管过期时间,请求一次就g对象就改变了一次,或者重新赋值了一次

from flask import Flask,g,render_template,request
from utils import login_log
app = Flask(__name__)
 
@app.route('/')
def hello_world():
    return 'Hello World!'
 
@app.route('/login/',methods=['GET','POST'])
def login():
    if request.method == 'GET':
        return render_template('login.html')
    else:
        username = request.form.get('username')
        password = request.form.get('password')
        if username == '111' and password == '222':
            g.username = '111'
            login_log()
            return u'登录成功'
        else:
            return u'您的用户名或密码错误'
 
if __name__ == '__main__':
    app.run()

 

posted @ 2020-06-30 19:50  驰念  阅读(175)  评论(0编辑  收藏  举报