前端项目public目录下的文件,部署到服务器后无法下载

问题回溯

这是一个外包项目,部署在本公司的域名的根路径下是可以下载的,但是部署到客户服务器时,是部署在网站根路径下的二级路由(/web-app)下的,这样就访问不到了

ini 复制代码
<div class="download"> 
    <a href="/static/file/auth.zip" download="授权文件.zip">下载授权资料</a>
</div>

问题分析

webpack是如何处理静态资源的

  1. 如src/assets中的文件通过相对路径被引用,这类引用会被webpack处理
  2. 放在public目录下或者通过绝对路径引用,这类资源会被直接拷贝,不会经过webpack处理

url转换规则

  1. 如果路径是绝对路径,会被原样保留
  2. 如果是相对路径,将会看作模块依赖被webpack处理
  3. 如果以@开头,也会被看作模块依赖,一般@的alias配给了src目录
  4. 如果以~开头,其后的部分将被看作模块依赖,既可以加载含有别名的静态资源,又可以加载node_modules的资源

结论

  1. 参照以上webpack的解析规则分析,这个引用是绝对路径而且在public中,webpack不做处理,webpack中配置的publicPath也自然作用不到这里,所以打包之后的路径仍是/static/file/auth.zip
  2. 当部署在网站的根路径时,点击a标签访问路径是https://xxx.com/static/file/auth.zip,是可以找到资源的
  3. 如果网站部署在网站根路径下/web-app之后,点击a标签访问路径是https://xxx.com/static/file/auth.zip,真实资源路径是https://xxx.com/web-app/static/file/auth.zip

问题解决

将访问路径由https://xxx.com/static/file/auth.zip转换为https://xxx.com/web-app/static/file/auth.zip即可,这里采用环境变量的方式将nginx的路由配置在.env文件中,也可以直接替换成/web-app,但是路由变动之后,改动会很多

xml 复制代码
<div class="download"> 
    <a :href="authPath" download="授权文件.zip">下载授权资料</a> 
</div> 
<script setup> 
import { Warning } from '@element-plus/icons-vue'
const authPath = `${process.env.VUE_APP_PUBLIC_PATH}/static/file/auth.zip` 
</script>

参考

Vue处理静态资源:public、assets目录 - vickylinj - 博客园 (cnblogs.com)

相关推荐
前端一课1 天前
【前端每天一题】🔥 事件循环第 6 题:setTimeout(fn, 0) 执行时机详解
前端·面试
前端一课1 天前
【前端每天一题】🔥 第3题 事件循环 20 道经典面试题(附详细答案)
前端·面试
前端一课1 天前
【前端每天一题】第 2 题:var、let、const 的区别?(绝对高频)
前端·面试
前端一课1 天前
【前端每天一题】🔥第四题 原型与原型链 - 前端面试必考题
前端·面试
初见0011 天前
告别无限循环:深入理解并征服 React Hooks 的依赖数组
前端
一颗不甘坠落的流星1 天前
【HTML】iframe 标签 allow 权限汇总(例如添加复制粘贴权限)
前端·javascript·html
亦草1 天前
浅谈现代前端体系:组件化、模块化、类型系统与工程化
前端
IT_陈寒1 天前
JavaScript开发者必知的7个ES2023新特性,让你的代码效率提升50%
前端·人工智能·后端
前端一课1 天前
【前端每天一题】🔥 第 1 题:什么是 闭包(Closure)?它有什么作用?
前端·面试
j***63081 天前
SpringbootActuator未授权访问漏洞
android·前端·后端