Python Web 之Flask基础(一)_python flask修改了视图函数的函数名-程序员宅基地

技术标签: Web 开发基础原理详解  Python web  Python3  web框架  Flask  

Flask 框架基础

Flask 搭建

Flask 1.0 文档

依赖
当安装 Flask 时,以下配套软件会被自动安装。

  • Werkzeug 用于实现 WSGI ,应用和服务之间的标准 Python 接口。
  • Jinja 用于渲染页面的模板语言。
  • MarkupSafe 与 Jinja 共用,在渲染页面时用于避免不可信的输入,防止注入攻击。
  • ItsDangerous 保证数据完整性的安全标志数据,用于保护 Flask 的 session cookie.
  • Click 是一个命令行应用的框架。用于提供 flask 命令,并允许添加自定义 管理命令。

可选依赖
以下配套软件不会被自动安装。如果安装了,那么 Flask 会检测到这些软件。

  • Blinker 为 信号 提供支持。
  • SimpleJSON 是一个快速的 JSON 实现,兼容 Python’s json 模块。如果安装 了这个软件,那么会优先使用这个软件来进行 JSON 操作。
  • python-dotenv 当运行 flask 命令时为 通过 dotenv 设置环境变量 提供支持。
  • Watchdog 为开发服务器提供快速高效的重载。

创建虚拟环境

创建一个项目文件夹,然后创建一个虚拟环境。

mkdir myproject
cd myproject
python -m venv venv

在开始工作前,先要激活相应的虚拟环境。

# Linux 下
. venv/bin/activate

# Windows下
venv\Scripts\activate

安装 Flask

python -m pip install Flask

在Windows平台命令行输入以上命令安装,可能会存在MarkupSafe依赖安装失败的问题,这主要是因为Windows命令行编码与Python中的不一致导致的问题。Windows命令行的默认编码是GBK,而Python3中默认编码是UTF-8,因此可以临时将Windows命令行切换为UTF-8编码

# 切换编码为utf-8
chcp 65001

#手动安装 markupsafe
python -m pip install markupsafe

# 安装完成后,请再次切回GBK。否则将导致以后使用cmd时出现各种奇怪的问题
# Windows系统的默认编码即GBK,请与系统保持一致。
chcp 936

如安装时缓慢或卡住,很可能是网络问题导致的,则建议使用国内源安装

# 使用清华大学的源
python -m pip install Flask -i https://pypi.tuna.tsinghua.edu.cn/simple

测试

  1. 创建hello.py文件,输入如下内容
    from flask import Flask
    app = Flask(__name__)
    
    @app.route('/')
    def hello_world():
        return 'Hello, World!'
    
  2. 导出 FLASK_APP 环境变量
    # Linux 下
    export FLASK_APP=hello.py
    flask run
    
    # Windows下
    set FLASK_APP=hello.py
    python -m flask run
    
  3. 在浏览器输入以下地址,正常显示Hello, World!
    http://localhost:5000/
    

Flask 的基本使用

路由

应用实例需要知道对每个URL的请求要运行哪些对应的函数,所以保存了一个URL到Python函数之间的映射关系。用于处理URL和函数之间关系的程序称为路由

在 Flask 应用中定义路由的最简便方式是使用Flask实例提供的 app.route 装饰器

@app.route('/')
def index():
    return 'Hello World!'

使用装饰器并不是唯一的把index()函数注册为应用根URL的处理程序的方式。实际上不使用装饰器语法也是可以做到的,我们可以通过调用app.add_url_ rule() 方法实现。该方法最简单的形式是接受3个参数:URL端点名视图函数

def index():
    return 'Hello World!'

app.add_url_rule('/', 'index', index)

视图函数

像上面代码中的hello_world()index() 这样处理客户端请求的函数被称为视图函数。在浏览器中访问相应的URL后,会触发服务器执行对应的视图函数。这个函数的返回值称为响应,也就是客户端浏览器接收到的内容。视图函数返回的响应可以是包含 HTML 的字符串,也可以是复杂表单。

当请求的URL中带有动态参数时,我们可以将视图函数与动态路由结合使用

@app.route('/greet/<name>')
def sayHello(name):
    return 'Hello, ' + name

增加以上代码后重新运行服务器,在浏览器输入:

http://localhost:5000/greet/Bob

则浏览器显示Hello, Bob

请求与响应

请求

Flask 从客户端收到请求时,将客户端发送的HTTP请求封装成了请求对象。想让视图函数能够访问请求对象,一种直截了当的方式是将其作为参数传入视图函数,不过这会导致应用中的每个视图函数都多出一个参数。为了避免大量可有可无的参数把视图函数弄得一团糟,Flask 使用上下文临时把某些对象变为全局可访问。

事实上它并不是真正的全局变量,在多线程服务器中,多个线程同时处理不同客户端发送的不同请求时,每个线程看到的请求对象必然不同。Flask 使用上下文让特定的变量在一个线程中全局可访问,与此同时却不会干扰其他线程。

示例代码

# 引入请求对象
from flask import request

@app.route('/')
def index():
    user_agent = request.headers.get('User-Agent')
    return 'Your browser is' + user_agent

请求对象包含客户端发送的 HTTP请求的全部信息

属性或方法 简述
form 一个字典,存储请求提交的所有表单字段
args 一个字典,存储通过 URL查询字符串传递的所有参数
values 一个字典,form 和args 的合集
cookies 一个字典,存储请求的所有 cookie
headers 一个字典,存储请求的所有 HTTP首部
files 一个字典,存储请求上传的所有文件
get_data() 返回请求主体缓冲的数据
get_json() 返回一个Python字典,包含解析请求主体后得到的 JSON
blueprint 处理请求的Flask 蓝本的名称
endpoint 处理请求的Flask端点的名称;Flask把视图函数的名称用作路由端点的名称
method HTTP请求方法,例如 GET 或POST
scheme URL方案(http 或https)
is_secure() 通过安全的连接(HTTPS)发送请求时返回 True
host 请求定义的主机名,如果客户端定义了端口号,还包括端口号
path URL的路径部分
query_string URL的查询字符串部分,返回原始二进制值
full_path URL的路径和查询字符串部分
url 客户端请求的完整URL
base_url 同url,但没有查询字符串部分
remote_addr 客户端的IP地址
environ 请求的原始WSGI环境字典
响应

Flask 调用视图函数后,会将其返回值作为响应的内容。大多情况下,响应就是一个简单的字符串,作为HTML页面返回给客户端。但 HTTP 协议需要的不仅是作为请求响应的字符串。HTTP 响应中一个很重要的部分是状态码,Flask默认设为 200,表明请求已被成功处理。

Flask有两种方式返回响应,一种是简单的利用多返回值,如下例,第二个参数为状态码

@app.route('/')
def index():
    return '<h1>Bad Request</h1>', 400

视图函数还可以返回三个参数,第三个参数是一个由 HTTP 响应头组成的字典。

如果不想使用视图函数的多返回值的方式返回响应,还可以使用另一种方式返回响应,那就是创建一个响应对象,然后让视图函数返回这个响应对象。

from flask import make_response

@app.route('/')
def index():
    response = make_response('<h1>This document carries a cookie!</h1>')
    response.set_cookie('thiscookie', '666')
    return response

响应对象常用属性和方法

属性或方法 简述
status_code HTTP数字状态码
headers 一个类似字典的对象,包含随响应发送的所有首部
set_cookie() 为响应添加一个cookie
delete_cookie() 删除一个cookie
content_length 响应主体的长度
content_type 响应主体的媒体类型
set_data() 使用字符串或字节值设定响应
get_data() 获取响应主体
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/yingshukun/article/details/86425385

智能推荐

ACM OJ Collection_htt//acm.wydtang.top/-程序员宅基地

文章浏览阅读737次。原文来自:http://blog.csdn.net/hncqp/article/details/4455263 ACM OJ Collection(排名不分先后):中国:浙江大学(ZJU):http://acm.zju.edu.cn/北京大学(PKU):htt_htt//acm.wydtang.top/

ios 自己服务器 苹果支付_修复苹果IOS支付-程序员宅基地

文章浏览阅读467次。更新记录1.0.0(2019-07-01)插件简介专门用来修复苹果IOS支付时出现"您已购买此App内购买项目。此项目将免费恢复"。问题描述首先在IOS平台里面创建“APP内购买项目”,选择的是“消耗型项目”,然后用uni-app官方的支付api进行支付,多支付几次,有时候就会出现提示“您已购买此App内购买项目。此项目将免费恢复”,特别是在沙盒测试里面支付很大几率出现,我明明选的是消耗型项目,应..._ios开发苹果支付恢复权益

spring MVC mock类单元测试(controller)_mvcmock-程序员宅基地

文章浏览阅读5.6k次。Spring从J2EE的Web端为每个关键接口提供了一个mock实现:MockHttpServletRequest几乎每个单元测试中都要使用这个类,它是J2EE Web应用程序最常用的接口HttpServletRequest的mock实现。MockHttpServletResponse此对象用于HttpServletRespons_mvcmock

【我的世界Minecraft-MC】常见及各种指令大杂烩【2022.8版】_summon生成掉落物-程序员宅基地

文章浏览阅读8.5k次,点赞7次,收藏22次。execute as @a at @s run clear @s minecraft:dark_oak_planks{display:{Name:“{“text”:“第三关[阴森古堡]”,“color”:“red”,“italic”:false}”,color:“16711680”},Enchantments:[{id:“protection”,lvl:1}],Unbreakable:1b} 1。Lore:[“{“text”:“免费”,“color”:“blue”,“italic”:false}”]..._summon生成掉落物

CentOS 7安装教程(图文详解)_centos 安装-程序员宅基地

文章浏览阅读10w+次,点赞487次,收藏2.1k次。CentOS 7安装教程: 准备: 软件:VMware Workstation 镜像文件:CentOS-7-x86_64-bin-DVD1.iso (附:教程较为详细,注释较多,故将操作的选项进行了加粗字体显示。) 1、文件--新建虚拟机--自定义 2、..._centos 安装

第1篇 目标检测概述 —(2)目标检测算法介绍_检测类算法的作用-程序员宅基地

文章浏览阅读1.4k次,点赞3次,收藏8次。目标检测算法是一种计算机视觉算法,用于在图像或视频中识别和定位特定的目标物体。本节课就给大家重点介绍下基于深度学习的目标检测算法!_检测类算法的作用

随便推点

Github项目分享——免费的画图工具drow,前端插件化面试_draw github画图-程序员宅基地

文章浏览阅读333次,点赞3次,收藏3次。项目介绍一款很好用的免费画图软件,支持ER图、时序图、流程图等等在项目的releases就可以下载最新版本同时支持在线编辑。_draw github画图

如何开始学习人工智能?入门的学习路径和资源是什么?_人工智能学习路径-程序员宅基地

文章浏览阅读930次。嗨,大家好!如果你对人工智能充满了好奇,并且想要入门这个领域,那么你来对地方了。本文将向你介绍如何从零基础开始学习人工智能,并逐步掌握核心概念和技能。无论你是大学生、职场新人还是对人工智能感兴趣的任何人,都可以按照以下学习路径逐步提升自己。_人工智能学习路径

Unity3D 导入资源_unity怎么导入压缩包-程序员宅基地

文章浏览阅读4.3k次,点赞2次,收藏8次。打开Unity3D的:window-asset store就会出来这样的界面:我们选择一个天空纹理,注意这里的标签只有一个,如果有多个就会显示所有标签的内容:找个比较小的免费的下载一下试试,比如这个:下载以后:点击import就会出现该窗口:然后再点击最底下的import:就导入到我们这里来了。从上面可以切换场景:..._unity怎么导入压缩包

jqgrid 服务器端验证,javascript – jqgrid服务器端错误消息/验证处理-程序员宅基地

文章浏览阅读254次。在你以前的问题的the answer的最后一部分,我试着给出你当前的问题的答案.也许我表示不够清楚.您不应该将错误信息放在标准成功响应中.您应该遵循用于服务器和客户端之间通信的HTTP协议的主要规则.根据HTTP协议实现网格中的加载数据,编辑行和与服务器的所有Ajax通信.每个HTTP响应都有响应第一行的状态代码.了解这个意义非常重要.典型的JSON数据成功请求如下HTTP/1.1 200 OK...._decode message error

白山头讲PV: 用calibre进行layout之间的比对-程序员宅基地

文章浏览阅读4k次,点赞8次,收藏29次。我们在流片之后,通常还是有机会对layout进行局部小的修改。例如metal change eco或者一些层次的局部修改。当我们修改之后,需要进行与之前gds的对比,以便确认没有因为某些..._calibre dbdiff

java exit方法_Java:如何测试调用System.exit()的方法?-程序员宅基地

文章浏览阅读694次。问题我有一些方法应该在某些输入上调用567779278。不幸的是,测试这些情况会导致JUnit终止!将方法调用放在新线程中似乎没有帮助,因为System.exit()终止了JVM,而不仅仅是当前线程。是否有任何常见的处理方式?例如,我可以将存根替换为System.exit()吗?[编辑]有问题的类实际上是一个命令行工具,我试图在JUnit中测试。也许JUnit根本不适合这份工作?建议使用互补回归测..._检查system.exit