spring mvc 文件下载
在web中下载的方式大多基于servlet,在web.xml中配置下载路径,这里再介绍json(转成base64字符串)和blob的使用方式
servlet
WEB-INF/web.xml
<!--url映射-->
<servlet-mapping><servlet-name>DowloadServlet</servlet-name><url-pattern>/servlet/dowloadFile</url-pattern>
</servlet-mapping><!--指定servlet-->
<servlet><servlet-name>DowloadServlet</servlet-name><servlet-class>com.xxxxxx.servlet.DowloadServlet</servlet-class>
</servlet>
servlet代码
protected void download(String path, String fileName) {File file = new File(path);if (!file.exists()) {logger.error("下载的文件不存在 path=" + path + ",fileName=" + fileName);}//下载OutputStream out = null;BufferedInputStream in = null;try {getResponse().setCharacterEncoding("UTF-8");getResponse().setContentType("application/vnd.ms-excel");getResponse().setHeader("Content-Disposition", "attachment; filename=" + fileName);out = getResponse().getOutputStream();in = new BufferedInputStream(new FileInputStream(path));int line;while ((line = in.read()) != -1) {out.write(line);}} catch (Exception ex) {logger.error("下载文件失败 path=" + path, ex);} finally {if (null != out) {try {out.close();} catch (Exception ex) {logger.error("关闭out异常 path=" + path, ex);}}if (null != in) {try {in.close();} catch (Exception ex) {logger.error("关闭in异常 path=" + path, ex);}}}}
js代码
通过浏览器进行下载
<a href="/serlvet/dowloadFile">下载</a> 或者window.open("/serlvet/dowloadFile")
blob
controller
关键在这响应头:application/octet-stream
protected void download(String path, String fileName) {File file = new File(path);if (!file.exists()) {logger.error("下载的文件模板不存在 path=" + path + ",fileName=" + fileName);}//下载OutputStream out = null;BufferedInputStream in = null;try {getResponse().setCharacterEncoding("UTF-8");getResponse().setContentType("application/octet-stream");getResponse().setHeader("Content-Disposition", "attachment; filename=" + fileName);out = getResponse().getOutputStream();in = new BufferedInputStream(new FileInputStream(path));int line;while ((line = in.read()) != -1) {out.write(line);}} catch (Exception ex) {logger.error("下载文件失败 path=" + path, ex);} finally {if (null != out) {try {out.close();} catch (Exception ex) {logger.error("关闭out异常 path=" + path, ex);}}if (null != in) {try {in.close();} catch (Exception ex) {logger.error("关闭in异常 path=" + path, ex);}}}}
js代码[引用博客]
// 通过后端接口下载文件
function downloadFile() {// 发起Ajax请求获取文件数据$.ajax({url: '/download',type: 'GET',dataType: 'binary',success: function(response) {// 创建Blob对象var blob = new Blob([response]);// 创建URL对象var url = URL.createObjectURL(blob);// 创建a标签并设置相关属性var link = document.createElement('a');link.href = url;link.download = 'file.txt';// 触发点击事件进行下载link.click();// 释放URL对象URL.revokeObjectURL(url);}});
}
json
controller
public Result execute() throws Exception {Result result = new Result();result.setErr_no(0);try {String xlsBase64 = xlsToBase64(param.getAbsDownPath(filePath);DataRow dr = new DataRow();dr.set("fileName",param.getFileName()+".xlsx");dr.set("fileBase64Str",xlsBase64);result.setResult(dr);}catch (Exception ex){result.setErr_no(-99);result.setErr_info("系统错误");logger.error("模板下载异常", ex);}return result;
}protected String xlsToBase64(String path){File file = new File(path);if (!file.exists()) {logger.error("下载的文件模板不存在 path=" + path );return null;}try{return Base64Util.encodeBase64String(FileUtils.readFileToByteArray(file));}catch (Exception e){logger.error("xls文件转Base64失败 path=" + path, e);}return null;}
javascript 【引用博客】
var raw = window.atob(data.result.fileBase64Str);
var uInt8Array = new Uint8Array(raw.length);
for (var i = 0; i < raw.length; i++) {uInt8Array[i] = raw.charCodeAt(i);
}const link = document.createElement("a");
const blob = new Blob([uInt8Array],{type: 'application/vnd.ms-excel'
})link.style.display = 'none';
link.href = URL.createObjectURL(blob);
link.setAttribute('download',data.result.fileName+'.xls');document.body.appendChild(link)
link.click()document.body.removeChild(link)
相关文章:
spring mvc 文件下载
在web中下载的方式大多基于servlet,在web.xml中配置下载路径,这里再介绍json(转成base64字符串)和blob的使用方式 servlet WEB-INF/web.xml <!--url映射--> <servlet-mapping><servlet-name>DowloadServlet</servlet-name>&l…...
Qt WebEngine基于WebEngineScript注入js脚本
在之前的文章中,我们介绍了Qt WebEngine注入js的用法,及runJavaScript()的用法,该方法主要是用在页面加载完成后,为了和网页做一些交互时使用。有时候需要监听网页加载完成的一些状态或信息,则需要网页加载前注入js来实…...
案例分享-国外UI设计界面赏析
国外UI设计倾向于简洁的布局和清晰的排版,减少视觉干扰,提升用户体验。通过合理的色彩搭配和图标设计,营造舒适愉悦的使用氛围。 设计师不拘泥于传统框架,勇于尝试新元素和理念,使界面独特有趣。同时,强调以…...
用PyTorch 从零开始构建 BitNet 1.58bit
我们手动实现BitNet的编写,并进行的一系列小实验证实,看看1.58bit 模型是否与全精度的大型语言模型相媲美! 什么是量化以及为什么需要它? 量化是用更少的比特数表示浮点数的过程。当两个数字使用不同的比特数进行量化时…...
信创安全 | 新一代内网安全方案—零信任沙盒
在当今数字化时代,访问安全和数据安全成为企业面临的重要挑战。传统的边界防御已经无法满足日益复杂的内网办公环境,层出不穷的攻击手段已经让市场单一的防御手段黔驴技穷。当企业面临越来越复杂的网络威胁和数据泄密风险时,更需要一种综合的…...
Redis的回收策略(淘汰策略)
volatile-lru :从已设置过期时间的数据集( server.db[i].expires )中挑选最近最少使用的数据淘汰 volatile-ttl : 从已设置过期时间的数据集( server.db[i].expires ) 中挑选将要过期的数据淘汰 volatile…...
Electron-builder 打包
项目比较简单,仅使用了 Electron 原生js 安装 electron-builder npm install electron-builder --dev配置 package.json 中的打包命令 {"script":{// ..."dev": "electron .","pack": "electron-builder"} }添…...
笔试练习day3
目录 BC149 简写单词题目解析代码 dd爱框框题目解析解析代码方法一暴力解法方法二同向双指针(滑动窗口) 除2!题目解析解法模拟贪心堆 感谢各位大佬对我的支持,如果我的文章对你有用,欢迎点击以下链接 🐒🐒🐒 个人主页 🥸…...
企业想要将大模型技术应用到企业管理中需具备什么条件?
#企业 #企业管理 #大模型 企业想要将大模型技术应用到企业管理中,需要考虑以下几个关键条件: 1.明确的需求定位:企业应首先诊断自身的业务场景、数据、算法、基础设施预算以及战略等能力,明确大模型能够为企业带来的具体赋…...
go 事件机制(观察者设计模式)
背景: 公司目前有个业务,收到数据后,要分发给所有的客户端或者是业务模块,类似消息通知这样的需求,自然而然就想到了事件,观察者比较简单就自己实现以下,确保最小功能使用支持即可,其…...
RISC-V竞赛|第二届 RISC-V 软件移植及优化锦标赛报名正式开始!
目录 赛事背景 赛道方向 适配夺旗赛 优化竞速赛 比赛赛题(总奖金池8万元!) 🔥竞速赛 - OceanBase 移植与优化 比赛赛程(暂定) 赛事说明 「赛事背景」 为了推动 RISC-V 软件生态更快地发展࿰…...
【VTK】ubuntu手动编译VTK9.3 Generating qmltypes file 失败
环境 硬件:Jetson Xavier NX 套件 系统:Ubuntu 20.04 软件 :QT5.15.6 解决 0、问题 最近在Jetson Xavier NX 套件上编译VTK库,因为想要配合QQuick使用,所以cmake配置时勾选了VTK_MODULE_ENABLE_VTK_GUISupportQtQu…...
学习java的日子 Day64 学生管理系统 web2.0 web版本
MVC设计模式 概念 - 代码的分层 MVC:项目分层的思想 字母表示层理解MModle模型层业务的具体实现VView视图层展示数据CController控制器层控制业务流程(跳转) 1.细化理解层数 Controller:控制器层,用于存放Servlet&…...
【第14章】Spring Cloud之Gateway路由断言(IP黑名单)
文章目录 前言一、内置路由断言1. 案例(Weight)2. 更多断言 二、自定义路由断言1. 黑名单断言2. 全局异常处理3. 应用配置4. 单元测试 总结 前言 Spring Cloud Gateway可以让我们根据请求内容精确匹配到对应路由服务,官方已经内置了很多路由断言,我们也…...
3、pnpm yarn npm
项目里实际上就只有这些依赖 node module 里却有很多的包 原因: 比如说vue,vue内部有依赖了其余的包。工具又依赖了别的依赖 造成的问题:我可以直接去用这个包,但是这个包在package.json中却没有看到-----幽灵依赖 那如果说别…...
❄️5. Kubernetes核心资源之名称空间和Pod实战
**什么是名称空间Namespace: ** Namespace是k8s系统中的一种非常重要资源,它的主要作用是用来实现多套环境的资源隔离或者多用户的资源隔离。默认情况下,k8s集群中的所有的Pod都是可以相互访问的。但是在实际中,可能不想让两个Pod之间进行互…...
锂电池充电板电路设计
写这篇文章的目的主要是个人经验的总结,希望能给开发者们提供一种锂电池充电电路以及电源显示的电路思路。接下来从以下几个方面讲述电路。 设计这款电路的初衷是想用一块硬币大小的锂电池作为供电电源(3.5V-4.2V),降压供给3.3V电…...
工业互联网产教融合实训基地解决方案
一、引言 随着“中国制造2025”战略的深入实施与全球工业4.0浪潮的兴起,工业互联网作为新一代信息技术与制造业深度融合的产物,正引领着制造业向智能化、网络化、服务化转型。为培养适应未来工业发展需求的高素质技术技能人才,构建工业互联网…...
高效批量提取PPT幻灯片中图片的方法
处理包含大量图片的PPT(PowerPoint)幻灯片已成为许多专业人士的日常任务之一。然而,手动从每张幻灯片中逐一提取图片不仅耗时耗力,还容易出错。为了提升工作效率,减少重复劳动,探索并实现一种高效批量提取P…...
怎么在 React Native 应用中处理深度链接?
深度链接是一种技术,其中给定的 URL 或资源用于在移动设备上打开特定页面或屏幕。因此,深度链接可以引导用户到应用程序内的特定屏幕,而不仅仅是启动移动设备上的应用程序,从而提供更好的用户体验。这个特定的屏幕可能位于一系列层…...
Python数据处理实战:列表推导式+time库+DataFrame+groupby详细代码注释
🚢 船长Talk | 每天一篇数据分析干货 关注公众号「船长Talk」,获取更多 Python / 数据分析 / SQL 实战技巧,附完整注释代码。 每篇文章都有详细代码注释,学了就能用。Python 数据处理实战:列表推导式 time库 DataFra…...
P6 v24.12 新功能实战:如何用‘基线预览’和‘取消链接’高效管理项目变更?
P6 v24.12 新功能实战:如何用‘基线预览’和‘取消链接’高效管理项目变更? 在复杂工程项目管理中,计划变更如同家常便饭。每次设计调整、资源变动或进度延误,都可能引发连锁反应。传统做法中,项目经理往往需要反复试…...
AI时代程序员必看!揭秘Harness Engineerin
当AI智能体开始批量编写代码,程序员会失业吗?OpenAI的一个实验给出了惊人答案:在一次实验中,3名工程师配合1500个AI智能体,竟在5个月内完成了100万行代码的产品开发——人类一行代码都没写!但背后真正的秘密…...
x86汇编堆栈
x86汇编堆栈 1)堆栈操作 x86汇编中的堆栈是一块特殊的内存区域,用于存储程序运行时的数据。它遵循"后进先出LIFO的原则",主要用于函数调用时的参数传递、局部变量存储以及保存返回地址。 堆栈操作的核心指令是PUSH和POP。PUSH指令将…...
分数阶效应下饱和非线性介质中艾里高斯光束传输仿真代码功能说明
Matlab光场调控的仿真代码(全套复现论文) 之前本科搞大创发了篇文章,纯搞光场调控的仿真,后来读研不做这个方向了,寻思卖了 Tips:本科生毕设,研究生搞理论的,领域为非线性光学的、光…...
别再手动改Excel了!用VBA的For Each循环,5分钟搞定1000行数据批量处理
解放双手:用VBA的For Each循环实现Excel数据批量处理革命 每天面对成百上千行的Excel数据,你是否还在重复着复制、粘贴、修改格式的机械操作?财务人员需要为所有金额添加货币符号,人力资源专员要统一调整员工编号格式,…...
基于粒子群算法的含分布式电源配电网动态无功优化程序——IEEE33节点配电网应用与性能分析
电力系统动态无功优化含分布式电源MATLAB程序IEEE33配电网 1)该程序为基于粒子群算法的含分布式电源配电网动态无功优化程序,期刊论文源程序,配有该论文。(2)该程序为动态无功优化,并且考虑了分布式电源的接…...
宠物管理系统|基于springboot+vue的宠物管理系统(源码+数据库+文档)
宠物管理系统 目录 基于springbootvue的宠物管理系统 一、前言 二、系统功能演示 完整操作流程 部署视频已录制完成 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取: 基于springbootvue的宠物管理系…...
7个实用技巧让你轻松掌握E-Hentai漫画下载与管理
7个实用技巧让你轻松掌握E-Hentai漫画下载与管理 【免费下载链接】E-Hentai-Downloader Download E-Hentai archive as zip file 项目地址: https://gitcode.com/gh_mirrors/eh/E-Hentai-Downloader 漫画下载痛点与解决方案 作为漫画爱好者,你是否遇到过这些…...
HuggingFace Transformers库中Tokenizer与Model的高效实践指南
1. 为什么Tokenizer和Model是NLP项目的基石 第一次接触HuggingFace Transformers库时,我被Tokenizer和Model这两个组件的配合方式惊艳到了。想象一下,Tokenizer就像一位专业的翻译官,把人类能看懂的文字转换成计算机能理解的数字密码…...
