解决Antd使用upload组件上传文件,使用action上传时跨越的问题

解决Antd使用upload组件上传文件,使用action上传时跨越的问题

问题描述

使用antd的upload处理图片上传场景,根据官方文档只需要定义好action、list-type、change事件就可以,其他大部分的页面效果组件都可以直接实现,比如打开本地文件系统,点击加载图片并上传到指定的远程服务器,但是如果此时远程由于CORS拒绝访问该怎么处理呢?

想要快速解决该问题的小伙伴可以跳过问题分析,直接参考解决过程

问题分析

跨域问题的出现其实就是前后端没有沟通好联系方式,打开谷歌调试工具的网络功能,先看一下接口预处理的报文(CORS在非简单请求时先进行预处理),因为接口预处理这部分是项目中配置好的,也就是不会出现跨域问题,而上传图片时采用的是Upload内置好的请求方式,upload并不关心你的项目里是怎么处理跨域的,所以在预处理之后很容易由于a-upload的请求头配置出现问题。

解决过程

拿到预处理请求的响应报文,观察报文头部的Access-Control-Allow-Headers,这个表示服务端返回的跨域请求中允许出现的请求头配置,如果上传了服务端不支持的配置就会报错,比如预处理响应中服务端返回了Access-Control-Allow-Headers:Content-Type,但是Upload组件的默认上传图片的请求头中有X-Requested-With:XMLHttpRequest 这个就是导致跨域失败的罪魁祸首!
删掉请求头中的X-Requested-With,尽管这个请求头是用来表示异步ajax请求的,但是为了成功跨域,需要使用Upload的headers属性,并且赋一个null值
在Upload组件中直接设置header时属性即可

headers: {
    X-Requested-With: null
}

还有一个需要注意的问题,如果页面访问使用的是https协议,那么Upload组件中的action值也需要是一个https协议,不然也会报错。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
使用 antd 组件 Upload上传文件给后端,你需要进行以下步骤: 1. 安装 antd 组件库: ``` npm install antd ``` 2. 在你的代码中引入所需的组件: ```jsx import { Upload, Button } from 'antd'; import { UploadOutlined } from '@ant-design/icons'; ``` 3. 创建一个状态来存储上传文件的列表: ```jsx const [fileList, setFileList] = useState([]); ``` 4. 创建一个函数来处理文件上传: ```jsx const handleUpload = () => { const formData = new FormData(); fileList.forEach(file => { formData.append('files', file); }); // 发送上传请求给后端 // 使用 axios 或其他 HTTP 库发送 POST 请求 // 例如: // axios.post('/api/upload', formData) // .then(response => { // // 处理上传成功后的逻辑 // }) // .catch(error => { // // 处理上传失败后的逻辑 // }); }; ``` 5. 在渲染的 JSX 中使用 Upload 组件: ```jsx <Upload fileList={fileList} onChange={({ fileList }) => setFileList(fileList)} > <Button icon={<UploadOutlined />}>选择文件</Button> </Upload> <Button onClick={handleUpload}>上传</Button> ``` 上述代码中,我们使用antdUpload 组件来创建一个文件上传的区域。通过设置 fileList 属性和 onChange 事件来管理上传的文件列表。当用户选择文件后,fileList 状态会自动更新。 最后,我们创建了一个按钮来触发 handleUpload 函数,该函数会将文件列表中的文件转换为 FormData,并发送 POST 请求给后端进行文件上传。 请注意,此处的上传逻辑仅为示例,具体的后端处理逻辑需要根据你的后端框架来实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天边彩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值