Axios 通过 FormData 上传文件

打印 上一主题 下一主题

主题 1023|帖子 1023|积分 3069

1.FormData先容

FormData 是一个用于在客户端创建表单数据的接口。可以通过 JavaScript 中的
new FormData() 构造函数创建。FormData 可以将表单字段的键值对以键值对的方式添加,
同时也支持添加文件。
2.FormData 的主要优点:



  • 可以异步上传文件
  • 可以上传二进制文件
  • 提交表单时主动处置惩罚表单数据编码
  • 可以上传文件流(Blob 对象和 File 对象)
3.FormData 对象上传文件

3.1第一种:直接在 FormData 中添加文件

将文件对象作为 value,添加到 FormData 中,axios 会主动对文件举行编码。
  1. const formData = new FormData();
  2. formData.append('file', fileInput.files[0]); // fileInput 为 <input type="file" />
  3. axios.post('/upload', formData)
复制代码
3.2第二种:设置 request header 的 Content-Type

  1. const formData = new FormData();
  2. formData.append('file', fileInput.files[0]);
  3. axios.post('/upload', formData, {
  4.   headers: {
  5.     'Content-Type': 'multipart/form-data'
  6.   }
  7. })
复制代码
 调用样例:
  1. function uploadFile() {
  2.   const fileInput = document.querySelector('#fileInput');
  3.   const file = fileInput.files[0];
  4.   // 使用FormData对象上传文件
  5.   const formData = new FormData();
  6.   formData.append('file', file);
  7.   axios.post('http://localhost:8089/upload', formData, {
  8.     headers: {
  9.       'Content-Type': 'multipart/form-data'
  10.     }
  11.   }).then(response => {
  12.     console.log('上传成功', response.data);
  13.   }).catch(error => {
  14.     console.error('上传失败', error);
  15.   });
  16. }
复制代码
4.选择文件案例

html:
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4.   <title>文件上传Demo</title>
  5. </head>
  6. <body>
  7.   <input type="file" id="fileInput">
  8.   <button onclick="uploadFile()">上传文件</button>
  9.   <script src="axios.min.js"></script>
  10.   <script src="main.js"></script>
  11. </body>
  12. </html>
复制代码
 JavaScript:
  1. function uploadFile() {
  2.   const fileInput = document.querySelector('#fileInput');
  3.   const file = fileInput.files[0];
  4.   // 使用FormData对象上传文件
  5.   const formData = new FormData();
  6.   formData.append('file', file);
  7.   axios.post('http://localhost:8089/upload', formData, {
  8.     headers: {
  9.       'Content-Type': 'multipart/form-data'
  10.     }
  11.   }).then(response => {
  12.     console.log('上传成功', response.data);
  13.   }).catch(error => {
  14.     console.error('上传失败', error);
  15.   });
  16. }
复制代码
5.图片base64转file上传案例

  1. let imgBase64 = "......"
  2. const formData = new FormData();
  3. formData.append('file', base64ToFile(imgBase64,"pointFile.jpg"));
  4. pointUpLoadFile(formData)
复制代码
  1. function base64ToFile(base64Data, filename) {
  2.   const parts = base64Data.split(';base64,');
  3.   const contentType = parts[0].split(':')[1];
  4.   const raw = window.atob(parts[1]);
  5.   const rawLength = raw.length;
  6.   const uInt8Array = new Uint8Array(rawLength);
  7.   for (let i = 0; i < rawLength; ++i) {
  8.     uInt8Array[i] = raw.charCodeAt(i);
  9.   }
  10.   const blob = new Blob([uInt8Array], {type: contentType});
  11.   const file = new File([blob], filename, {type: contentType});
  12.   return file;
  13. }
复制代码
  1. function pointUpLoadFile(formData){
  2.   axios.post('http://localhost:8089/upload',formData,{
  3.           headers: {
  4.             'Content-Type': 'multipart/form-data'
  5.           }
  6.         }).then(response=>{
  7.           console.log('上传成功', response.data);
  8.         }).catch(error=>{
  9.           console.error('上传失败', error);
  10.         })
  11. }
复制代码


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

反转基因福娃

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表