问题回溯
这是一个外包项目,部署在本公司的域名的根路径下是可以下载的,但是部署到客户服务器时,是部署在网站根路径下的二级路由(/web-app)下的,这样就访问不到了
ini
<div class="download">
<a href="/static/file/auth.zip" download="授权文件.zip">下载授权资料</a>
</div>
问题分析
webpack是如何处理静态资源的
- 如src/assets中的文件通过相对路径被引用,这类引用会被webpack处理
- 放在public目录下或者通过绝对路径引用,这类资源会被直接拷贝,不会经过webpack处理
url转换规则
- 如果路径是绝对路径,会被原样保留
- 如果是相对路径,将会看作模块依赖被webpack处理
- 如果以@开头,也会被看作模块依赖,一般@的alias配给了src目录
- 如果以~开头,其后的部分将被看作模块依赖,既可以加载含有别名的静态资源,又可以加载node_modules的资源
结论
- 参照以上webpack的解析规则分析,这个引用是绝对路径而且在public中,webpack不做处理,webpack中配置的publicPath也自然作用不到这里,所以打包之后的路径仍是/static/file/auth.zip
- 当部署在网站的根路径时,点击a标签访问路径是https://xxx.com/static/file/auth.zip,是可以找到资源的
- 如果网站部署在网站根路径下/web-app之后,点击a标签访问路径是https://xxx.com/static/file/auth.zip,真实资源路径是https://xxx.com/web-app/static/file/auth.zip
问题解决
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>