近期有一些朋友,在做上传图片这一块的时候进度卡住了。有个朋友说,我已经在这个问题上浪费了一天了。

确实,对于新手而言,上传图片成了比较复杂的的一个事,今天整理了一下常用的两种方式,让新手轻松掌握上传图片的小难题。

(一)form表单上传

这种方式简单暴力,如果没有特殊需求,数据和图片一次性处理的时候,这种方式,最合适不过。

<b>前端的代码:</b>


&lt;form action="upload" method="post" enctype="multipart/form-data"&gt;
&lt;input type="file" name="pic" /&gt;
&lt;input type="submit" value="上传" /&gt;
&lt;/form&gt;
  • action 请求的后端方法
  • enctype="multipart/form-data" 在使用包含文件上传控件的表单时,必须使用该值。

<b>后端的代码:</b>


public function upload(){
// 获取上传的图片
$pic = $_FILES['pic']['tmp_name'];
$upload_ret = false; if($pic){
// 上传的路径,建议写物理路径
$uploadDir = 'static/upload';
// 创建文件夹
if(!file_exists($uploadDir)){
mkdir($uploadDir, 0777);
}
// 用时间戳来保存图片,防止重复
$targetFile = $uploadDir . '/' . time() . $_FILES['pic']['name'];
// 将临时文件 移动到我们指定的路径,返回上传结果
$upload_ret = move_uploaded_file($pic, $targetFile) ? true : false;
} return $upload_ret;
}

简单的一个form表单上传文件就搞定了!

(二)ajax 无刷新上传图片

传统的form表单提交会导致页面刷新,但是在有些情况下,我们不希望页面被刷新,这种时候我们都是使用ajax的方式进行请求的。

很多人肯定会想到JQuery的ajax操作,但是这样的做法是没用的,因为只能传递一般的参数,文件是无法上传的。

这个时候 有一个叫做FormData的东西的出现拯救了我们

关于FormData

XMLHttpRequest Level 2添加了一个新的接口FormData,利用FormData对象,我们可以通过JavaScript用一些键值对来模拟一系列表单控件,我们还可以使用XMLHttpRequest的send()方法来异步的提交这个"表单"。比起普通的ajax,使用FormData的最大优点就是我们可以异步上传一个二进制文件。

所有主流浏览器的较新版本都已经支持这个对象了,比如Chrome 7+、Firefox 4+、IE 10+、Opera 12+、Safari 5+。

参见:https://developer.mozilla.org/zh-CN/docs/Web/API/FormData

  • 原生的XMLHttpRequest 实现

前端的代码:


&lt;form&gt;
&lt;input type="file" name="pic" id="pic"/&gt;
&lt;input type="button" onClick="upload()" value="上传" /&gt;
&lt;/form&gt;

js的代码:


function upload(){
// 请求的后端方法
var url="upload";
// 获取文件
var pic = document.getElementById('pic').files[0]; // 初始化一个 XMLHttpRequest 对象
var xhr = new XMLHttpRequest();
// 初始化一个 FormData 对象
var form = new FormData(); // 携带文件
form.append("pic", pic);
//开始上传
xhr.open("POST", url, true);
//在readystatechange事件上绑定一个事件处理函数
xhr.onreadystatechange=callback;
xhr.send(form); function callback() {
if(xhr.readyState == 4){
if(xhr.status == 200){
if(xhr.responseText == 1){
alert('添加成功');
window.location.reload();
}else{
alert("添加失败");
}
}
}
}
}

参见:https://developer.mozilla.org/zh-CN/docs/Web/Guide/Using_FormData_Objects

后端代码:

如方法一,不变。

  • JQuery + FormData 实现

其实JQuery也是可以操作的,不过老版本不支持,所以建议使用2.0及更新版本。

前端代码:


&lt;form id= "upload_form"&gt;
指定文件名:&lt;input type="text" name="filename" /&gt;
上传文件:&lt;input type="file" name="file"/&gt;
&lt;input type="button" value="上传" onclick="upload()" /&gt;
&lt;/form&gt;

js代码:


function upload(){
var form = new FormData($("#upload_form")[0]);
$.ajax({
url:'upload',
type:'POST',
data:form,
success:function (result){
alert(result);
},
error:function (result){
alert(result);
}
});
}

后端代码:

如方法一,不变。

无刷新的上传图片功能,也轻松的搞定了!

总结

一般根据业务选择对应的方式来实现,文章里面主要是告诉大家如何实现,一些细节处理,还是需要大家自己去处理。

如有疑问或者建议,都可以联系我。

原文地址:https://www.jianshu.com/p/b7f5a706d7da

最新文章

  1. My TWI
  2. springmvc:jsp fmt标签格式化Date时间,格式化后可以用于页面展示
  3. 【MongoDB:第二天】基本操作
  4. MVC筛选自定义属性下拉表
  5. .Net最佳实践3:使用性能计数器收集性能数据
  6. mysql数据库入门
  7. HTML5音频,视频播放
  8. C#For循环
  9. 解压版tomcat设置为系统服务
  10. USB C和USB 3.1傻傻分不清?这篇文章可以帮你
  11. 【转载】vim复制时的缩进
  12. redis绑定ip以及启动和查看启动状态
  13. Python内置方法的时间复杂度
  14. MySQL 修改账号的IP限制条件
  15. python基础篇实战
  16. [日常] HTTP的媒体类型
  17. socket FTP-1
  18. Python学习-环境搭建(IronPython)
  19. rsync+sersync+inotify实现服务器间文件同步之一
  20. AsyncTask异步类的简单操作

热门文章

  1. 第二十篇:记下第一个mysql触发器
  2. idea 提交拉取代码,解决冲突
  3. Kindle电子书制作
  4. Spring MVC上传、下载 文件
  5. Jpgraph小应用
  6. soj97 旅行
  7. 廖雪峰Java12maven基础-2maven进阶-2模块管理
  8. Python-函数基础(1)
  9. php包含文件
  10. System.Web.Mvc.FilePathResult.cs