问题描述
在vue项目中我们发送 ajax 请求一般都会使用 axios,并在 axios 中设置axios.defaults.baseURL,请求的基本地址,并在请求拦截器中设置 headers
使用 el-upload 上传组件时,action 为必选参数,上传的地址。
但此时我们为action填写地址不能不写基本地址而仅写 upload,要写完整的地址。
这是因为 el-upload 上传组件在上传发送请求时,不会去使用我们设置的 axios,而是在组件内部自己封装了自己的请求方法。所以我们必须把地址写完整。
那有时在上传时会报出错误,例如"无效token",这是因为我们没有为此上传请求设置请求头部。el-upload 组件有一个属性 headers ,设置上传的请求头部。
解决方案
HTML 代码
html
<el-upload class="upload-demo" drag
:action=uploadPath
multiple="true"
accept=".pdf, .xlsx, .xls"
:headers="headers"
:show-file-list="false"
:on-change="handleChange">
<el-icon class="el-icon--upload"><upload-filled /></el-icon>
<div class="el-upload__text">
ドラッグ・ドロップもしくはクリックしてファイルを選択してください
</div>
<template #tip>
<div class="el-upload__tip">
PDF のみアップロードできます
</div>
</template>
</el-upload>
JS 代码
javaScript
<script setup>
import { useUserStore } from '@/store/user'
const userStore = useUserStore()
const token = userStore.userInfo.token
const Authorization = `Bearer ${token}`
const headers = ref({'Authorization':Authorization})
</script>