Flask 应用中图片动态更新与上传:实现客户端定时刷新与服务器端文件管理

flask 应用中图片动态更新与上传:实现客户端定时刷新与服务器端文件管理

本教程详细介绍了如何在 Flask 应用中高效地显示和动态更新图片。内容涵盖 Flask 静态文件服务、HTML 模板中图片路径的正确引用、利用 JavaScript 实现客户端图片定时刷新(包括缓存处理),以及服务器端图片上传处理的完整流程,旨在帮助开发者构建具备图片管理功能的 Web 应用。

1. Flask 基础:静态文件服务与图片显示

在 Flask 应用中,静态文件(如 CSS、JavaScript、图片等)通常通过一个名为 static 的特殊文件夹来提供。在 HTML 模板中,url_for() 函数结合 static 端点是生成静态文件正确 URL 的标准方式。

1.1 项目结构

为了清晰地组织文件,建议采用以下项目结构:

.├── app.py                  # Flask 主应用文件├── static│   └── images│       └── chart.png       # 示例图片文件└── templates    └── chart.html          # HTML 模板文件

1.2 Flask 应用配置与路由

app.py 中,我们需要配置静态文件目录,并定义一个路由来渲染包含图片的 HTML 页面。

import osfrom flask import Flask, render_templateapp = Flask(__name__)# 配置图片上传目录,该目录位于 'static' 文件夹下app.config['UPLOAD_FOLDER'] = os.path.join('static', 'images')@app.route("/")def running():    """根路由,简单返回应用运行状态"""    return "

Website running!

"@app.route("/chart")def show_img(): """ 显示图片的路由。 将图片的相对路径(相对于 static 文件夹)传递给模板。 """ # 假设图片名为 chart.png,且位于 static/images 目录下 # url_for('static', ...) 会自动处理 'static/' 部分 image_path_in_static = os.path.join('images', 'chart.png') return render_template("chart.html", user_image=image_path_in_static)if __name__ == "__main__": # 启动 Flask 应用,开启 debug 模式方便开发 app.run(port=3000, debug=True)

1.3 HTML 模板中的图片引用

在 templates/chart.html 中,使用 url_for() 函数来引用 user_image 变量,确保图片路径正确解析。

        动态图片展示    

当前图片

@@##@@

此时,访问 http://localhost:3000/chart 路由即可在浏览器中看到 chart.png 图片。

2. 客户端定时刷新图片

当服务器端的图片文件内容发生变化,但文件名保持不变时,浏览器可能会因为缓存机制而继续显示旧图片。为了强制浏览器重新加载最新图片,我们需要利用 JavaScript 定时更新 Chart Image 标签的 src 属性,并在 URL 中添加一个唯一的查询参数(例如时间戳)来“破坏”缓存。

2.1 修改 chart.html 添加 JavaScript 刷新逻辑

        动态图片展示    

当前图片

@@##@@ // 获取图片元素 const dynamicImage = document.getElementById('dynamicImage'); // 获取原始图片路径,用于构建新的 URL。 // .split('?')[0] 用于移除可能已存在的查询参数。 const originalSrc = dynamicImage.src.split('?')[0]; // 每5秒刷新一次图片 setInterval(() => { // 生成一个当前时间戳作为查询参数,强制浏览器重新加载图片,避免缓存 const newSrc = originalSrc + '?' + new Date().getTime(); dynamicImage.src = newSrc; console.log('Image refreshed:', newSrc); }, 5000); // 5000毫秒 = 5秒

通过上述 JavaScript 代码,每隔 5 秒,浏览器会请求一个新的图片 URL(因为 URL 上的时间戳不同),从而绕过浏览器缓存,显示最新的图片内容。

3. 服务器端图片上传与管理

如果图片是由用户上传或服务器动态生成并需要替换现有文件,我们需要在 Flask 应用中实现文件上传功能。这涉及到接收文件、验证文件类型、安全地保存文件等步骤。

3.1 扩展 app.py:实现文件上传功能

我们需要引入 request, redirect, url_for, flash 和 werkzeug.utils.secure_filename。为了演示目的,我们使用一个全局变量 current_file 来跟踪当前显示的图片,但在生产环境中,应避免使用全局变量,而应采用数据库或会话管理来存储文件信息。

import osfrom flask import Flask, render_template, request, redirect, url_for, flashfrom werkzeug.utils import secure_filename # 用于安全地处理文件名app = Flask(__name__)app.secret_key = 'supersecretkey_for_flash_messages' # flash 消息需要 secret_key# 配置图片上传目录UPLOAD_FOLDER = os.path.join('static', 'images')ALLOWED_EXTENSIONS = {'png', 'jpg', 'jpeg', 'gif'} # 允许的图片扩展名app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER # 将配置赋值给 app.config# 用于存储当前显示的图片文件名(仅为演示目的,生产环境应避免全局变量)current_file = 'chart.png' # 默认图片名def allowed_file(filename):    """检查文件是否是允许的

Flask 应用中图片动态更新与上传:实现客户端定时刷新与服务器端文件管理Chart Image

以上就是Flask 应用中图片动态更新与上传:实现客户端定时刷新与服务器端文件管理的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1599919.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月23日 14:12:25
下一篇 2025年12月23日 14:12:35

相关推荐

  • JavaScript与CSS动画:实现平滑顺序淡入淡出效果并解决显示冲突

    本文深入探讨了如何利用css动画和javascript实现元素的顺序淡出淡入效果,并着重解决了因`display: none`立即应用而导致的淡出动画不播放问题。文章提供了基于`settimeout`和更健壮的`animationend`事件的解决方案,并进一步建议使用css `transition…

    2025年12月23日
    000
  • 如何定制PrimeNG Sidebar的背景颜色

    本文将详细指导您如何有效修改PrimeNG Sidebar组件的背景颜色。针对直接样式绑定和局部CSS作用域失效的问题,我们将提供一种直接且高效的解决方案:通过全局CSS覆盖PrimeNG默认样式。文章将深入解释其原理,并提供详细的代码示例和最佳实践,确保您能成功实现自定义效果。 理解PrimeNG…

    2025年12月23日
    000
  • 在PHP环境中正确加载HTML资源:CSS样式与图片路径指南

    当html和css集成到php项目时,常见的挑战是图片和部分css样式(如背景图)无法正常加载,而字体等其他样式却能显示。这通常源于文件路径引用不正确。本文将深入探讨在php环境下正确设置css样式表和图片资源路径的方法,强调使用标准的html标签和合适的路径类型,以确保所有前端资源都能被服务器正确…

    2025年12月23日
    000
  • 为WordPress产品名称添加必填(Required)属性的教程

    本教程详细介绍了如何在wordpress中为产品名称字段添加html的`required`属性,从而强制用户在发布或更新产品时必须填写该字段。文章强调了避免直接修改wordpress核心文件的重要性,并提供了一种通过使用wordpress钩子(hooks)和自定义javascript代码来实现此功能…

    2025年12月23日
    000
  • 使用jQuery动态替换下拉列表选项:插入自定义单一值

    本教程详细介绍了如何使用jquery动态清空html “下拉列表中的所有现有选项,并插入一个全新的、自定义的单一选项。我们将探讨核心的`remove().end().append()`链式操作,并重点讲解如何在插入新选项时正确地将javascript变量内容整合到html字符串中,以实现…

    2025年12月23日
    000
  • 消除网页顶部意外空白线:CSS布局常见问题与解决方案

    本教程探讨网页顶部出现意外空白线或间隙的常见原因,特别是与html header元素相关的布局问题。文章将详细介绍如何通过css重置默认样式、理解外边距折叠以及使用负外边距等方法,有效解决此类视觉瑕疵,确保页面布局的精确性与专业性。 在网页设计与开发中,我们有时会遇到页面顶部出现一条不期而至的空白线…

    2025年12月23日
    000
  • 纯CSS实现自适应宽度与响应式布局的水平按钮组

    本教程详细介绍了如何利用纯css创建一组响应式水平按钮。通过结合flexbox布局、max-content属性和媒体查询,我们能实现按钮组宽度根据最长文本自适应、按钮等宽、文本自动换行,并在小屏幕上自动堆叠成列的效果,确保在不同设备上提供一致且优化的用户体验。 在现代网页设计中,创建一组具有良好适应…

    2025年12月23日
    000
  • Bootstrap 5导航栏折叠功能失效:数据属性迁移指南

    本文详细介绍了从bootstrap 4迁移到bootstrap 5时,导航栏折叠功能失效的常见原因及解决方案。核心在于bootstrap 5将数据属性前缀从`data-`更改为`data-bs-`。教程提供了具体的代码示例,帮助开发者正确配置导航栏的`data-bs-toggle`和`data-bs…

    2025年12月23日
    000
  • HTML Canvas文本样式定制指南:解决外部字体加载与应用难题

    本文详细阐述了在html canvas中应用外部自定义字体时遇到的常见问题及其解决方案。主要聚焦于`context.font`属性中多词字体名称的正确引用方式,以及如何利用`document.fonts.ready`确保外部字体在绘制前已完全加载,从而避免字体应用失败或回退到默认字体的问题,提供了一…

    2025年12月23日
    000
  • 在React和JavaScript应用中提交表单时保持URL整洁的策略

    提交html表单时,默认的get方法会将表单数据附加到url中,导致url冗长且暴露数据。为避免此问题,应使用post方法,它将数据封装在http请求体中发送,从而保持url路径的简洁和数据隐私。 理解表单数据在URL中出现的原因 当我们在网页中使用HTML 以上就是在React和JavaScrip…

    2025年12月23日
    000
  • Linux OpenLiteSpeed,CSS预加载HTML渲染加速!

    启用OpenLiteSpeed的CSS预加载与HTML渲染优化可显著提升页面加载速度。1、在控制台虚拟主机的Context中添加静态资源上下文,设置CSS路径并启用HTTP/2 Push;2、在HTML的head中加入rel=”preload”标签,提前加载关键CSS文件;3…

    2025年12月23日
    000
  • Windows SharpKeys重映射,CSS快捷键HTML专属!

    首先通过SharpKeys修改注册表映射不常用键如Scroll Lock为F13,再利用AutoHotkey脚本监听F13并发送HTML或CSS代码片段,例如F13触发插入div标签,F14插入margin: 0; padding: 0;,从而提升前端编码效率。 如果您希望在Windows系统中通过…

    2025年12月23日
    000
  • PowerToys FancyZones分区,HTML+CSS工作区高效!

    FancyZones可通过自定义网格模拟CSS Grid布局,使用模板实现Flexbox式%ignore_a_1%,设置快捷键快速切换分区,并开启对齐辅助线提升窗口定位精度,结合多桌面优化多任务管理效率。 如果您希望在Windows系统中实现类似HTML+CSS布局的高效工作区管理,PowerToy…

    2025年12月23日
    000
  • Opera DevTools热重载,HTML改CSS页面瞬变!

    Opera DevTools 热重载功能可在保存 HTML 或 CSS 文件时实时更新页面样式,提升开发效率。首先需在 DevTools 设置中启用“自动重载”,随后通过本地服务器(如 npx http-server)运行项目以支持文件监听。配合 VS Code 等编辑器的 Live Server …

    2025年12月23日
    000
  • Linux i3窗口管理,HTML+CSS布局自定义王!

    可通过Conky结合HTML/CSS渲染桌面信息,使用YAMi构建浏览器式控制面板,并利用i3blocks自定义状态栏样式实现i3窗口管理器下的高度定制化界面。 如果您正在使用 Linux 系统并选择了 i3 窗口管理器,想要通过 HTML 和 CSS 实现自定义布局界面来增强桌面美观性与功能性,则…

    2025年12月23日
    000
  • Mac DevonThink搜索,HTML+CSS代码库秒定位!

    重建索引并使用高级搜索语法和标签可解决DevonThink搜索不准确问题:一、通过“数据库>重建索引”刷新文档记录;二、在搜索框输入”k=html”、”c=css”或”path:snippets html button”实…

    2025年12月23日
    000
  • Laragon一键环境,HTML引用CSS路径永正确!

    HTML无法加载CSS因路径错误,需将项目放Laragon的www目录;使用如css-demo命名文件夹并重载虚拟主机;用相对路径href=”css/style.css”或绝对路径http://myproject.test/css/style.css引入样式;检查httpd.…

    2025年12月23日
    000
  • Windows Snap Layouts,HTML编辑CSS预览分区王!

    首先启用Windows Snap Layouts功能,通过设置中的多任务处理选项开启贴靠布局,将鼠标悬停在窗口最大化按钮上选择分屏布局,实现VS Code与浏览器左右并排;接着在VS Code中安装Live Server插件,右键HTML文件选择“Open with Live Server”启动实时…

    2025年12月23日
    000
  • Mac Tower可视分支,CSS改动HTML历史一览!

    首先启用Mac Tower的Branch Graph模式查看分支可视化,再通过File Filter筛选CSS和HTML文件修改记录,接着比较选定提交间的差异以分析样式对结构的影响,然后查看特定HTML文件的完整修改历史并关联CSS变动,最后创建自定义标签标记重要更新节点以便追溯。 如果您在使用 M…

    2025年12月23日
    000
  • Mac Sonoma TextEdit防坑,CSS注入HTML无痛融合!

    首先切换TextEdit至纯文本模式并禁用智能引号,再以UTF-8编码保存为.html文件,最后检查HTML结构与CSS路径确保样式正确加载。 如果您在使用 Mac Sonoma 系统中的 TextEdit 编辑 HTML 文件时,发现样式无法正常显示或内容被自动修改,可能是由于 TextEdit …

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信