当前位置: 首页 > news >正文

图片预览 图片上传到服务器

首先要明白 理解 multipart/form-data:multipart/form-data是一种在HTTP请求中使用的MIME类型,主要用于在客户端和服务器之间传输包含文件或二进制数据的表单数据。它通过一个边界(boundary)来分隔不同的表单字段和文件数据‌。

简单来说multipart/form-data类型用于form表单中确保文件内容完整传输

使用场景

multipart/form-data主要用于以下场景:

  • 文件上传‌:当表单中包含文件上传字段时,必须使用multipart/form-data编码方式,因为它可以将文件以二进制形式传输‌。
  • 二进制数据传输‌:除了文件,还可以传输其他二进制数据,如图片、音频等。

实际应用

在HTML表单中,enctype属性用于指定表单数据的编码方式。默认情况下,enctype的值为application/x-www-form-urlencoded,适用于文本数据的传输。但当需要上传文件时,必须将enctype设置为multipart/form-data,以确保文件内容能够完整传输‌

案例如下

<input type='file'>

<img src=''" alt ="用于图片预览“> 

<button type='button">确认上传</button>

<div class="form-group"><label for="inputPassword3" class="col-sm-2 control-label">景点图片:</label><div class="col-sm-10 d-flex"><div style="display: flex;"><input type="file" name="cover" id="inputFile"><button type="button" class="btn btn-sm" id="sureUp">上传图片</button></div><img src="" id="yl" alt=""></div></div>

上传之后 先预览 在确定是否上传到服务器

new FileReader()‌ 是JavaScript中的一个内置对象,用于在客户端(浏览器)中异步读取文件内容。它提供了一种将文件内容读取到内存中以供处理的方式,适用于读取不同类型的文件,如文本文件、图像文件等。

var reader = new FileReader(); // 创建新的FileReader实例

reader.onload = function(){

获取文件内容函数

}

reader.readAsText(file); // 以文本格式读取文件内容

 reader.readAsDataURL() //以base64 读取图片


  var file = '';//用于存需要上传的图片$('#inputFile').change(function () {if (this.files && this.files[0]) {file = this.files[0]var reader = new FileReader();reader.onload = function (e) {$('#yl').attr('src', e.target.result);};reader.readAsDataURL(this.files[0]); // 读取文件内容}})$('#sureUp').click(function () {var formData = new FormData();formData.append('file', file);// file (后台接收的参数)$.ajax({url: 'http://127.0.0.1:8088/api/upload', // 你的图片上传接口type: 'POST',data: formData,contentType: false, // 不设置内容类型processData: false, // 不处理发送的数据success: function (response) {console.log(res)}})})

http://www.lryc.cn/news/493010.html

相关文章:

  • 前端:base64的作用
  • Django在fitler过滤不等于的条件
  • Spring Boot英语知识分享网站:技术与实践
  • 京准电钟:NTP网络校时服务器从入门到精准
  • C++趣味编程玩转物联网:用树莓派Pico控制四位数码管
  • DRM(数字权限管理技术)防截屏录屏----视频转hls流加密、web解密播放
  • 实验三 z变换及离散时间LTI系统的z域分析
  • Python中的DrissionPage详解
  • python除了熟悉的pandas,openpyxl库也很方便的支持编辑Excel表
  • go语言怎么实现bash cmd里的mv功能?
  • Vue前端面试进阶(五)
  • 面试手撕题积累
  • notepad++文件github下载
  • .NET新知识点笔记
  • 数据结构:链表进阶
  • Python 爬虫入门教程:从零构建你的第一个网络爬虫
  • Java面试题、八股文——JVM篇最终篇
  • Spring Boot整合Redis Stack构建本地向量数据库相似性查询
  • shell脚本基础学习_总结篇(完结)
  • 什么是 C++ 中的函数对象?它有什么特点?
  • css:项目
  • macOS 开发环境配置与应用开发指南
  • [A-19][V06]ARMv8/v9-内存虚拟化原理
  • registry 删除私有仓库镜像
  • UPLOAD LABS | UPLOAD LABS 靶场初识
  • Samba服务器常见问题处理
  • Java基础 设计模式——针对实习面试
  • 最大公约数和最小公倍数-多语言
  • 第三方数据库连接免费使用和安装
  • 水库大坝安全监测之量水堰计应用