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

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

(一)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

js+php如何实现上传图片的更多相关文章

  1. js兼容火狐显示上传图片预览效果

    js兼容火狐显示上传图片预览效果[谷歌也适用] <!doctype html> <html> <head> <meta content="text/ ...

  2. 关于ajaxfileupload.js一些问题和上传图片就立即显示图片功能

    ajaxfileupload.js是上传文件的一个插件,最近碰到的一个问题是在谷歌浏览器上传文件之后,原文本框中的文件名称消失,网上搜了好长时间也没有十分满意的答案.无刷新上传文件我想到的只有ajax ...

  3. js实现ctrl+v上传图片

    描述:实现类似QQ截图删上传图片的功能 a.需要的js插件 paste.image.js 地址:https://github.com/iyangyuan/pasteimg b.paste.image. ...

  4. JS调用摄像头并上传图片到服务器

    本功能只能把图片转成base64码上传,如何上传图片还没有修改出来,有兴趣的朋友弄出来了,请给我留下言,谢谢了! 直接上代码,需要的朋友直接复制就可以使用了. <!DOCTYPE html> ...

  5. js 压缩 预览 上传图片

    com.js export const compressImage=function (files,fn,preCallbackFn,i) { let newfile = files.files[0] ...

  6. JS中使用FormData上传图片

    <!DOCTYPE html> <html> <head> <meta name="viewport" content="wid ...

  7. js 原生 ajax 异步上传图片

    <script type="text/javascript"> function upload() { var file1 = document.getElementB ...

  8. JS将图片文件转为64位字符串再post到接口上传图片

    HTML: <div class="ai-item upload-id-img"> <p>上传身份证照片</p> <div class=& ...

  9. Js上传图片并生成缩略图

    Js上传图片并显示缩略图的流程为 Js选择文件->Jquery上传图片->服务器接收图片流->存储图片->返回结果到Js端->显示缩略图 本文上传图片所用的Js库是aja ...

随机推荐

  1. <linux常用命令>初级版

    显示时间 date 显示日历cal 变换目录 cd 显示当前所在目录 pwd 建立新目录 mkdir -p a/b/c 删除空目录 rmdir 当前目录下文件和目录显示 ls 复制 cp 文件 路径 ...

  2. 一个tcp连接可以发多少http请求

    -----来自:松若章 -----zhuanlan.zhihu.com/p/61423830 曾经有这么一道经典面试题:从 URL 在浏览器被被输入到页面展现的过程中发生了什么?相信大多数准备过的同学 ...

  3. OpenGL键盘交互响应事件

    GLUT允许我们编写程序,在里面加入键盘输入控制,包括了普通键,和其他特殊键(如F1,UP).在这一章里我们将学习如何去检测哪个键被按下,可以从GLUT里得到些什么信息,和如何处理键盘输入.   处理 ...

  4. CF596D Wilbur and Trees

    题意:有一些高度为h的树在数轴上.每次选择剩下的树中最左边或是最右边的树推倒(各50%概率),往左倒有p的概率,往右倒1-p. 一棵树倒了,如果挨到的另一棵树与该数的距离严格小于h,那么它也会往同方向 ...

  5. 如何在屏幕上查看命令的输出以及在Linux中写入文件

    在Linux中输出命令可以做很多事情(http://www.nanke0834.com) 您可以将命令的输出分配给变量,将其发送到另一个命令/程序以通过管道进行处理或将其重定向到文件以进行进一步分析. ...

  6. IOS学习笔记56-IOS7状态栏适配方法一

    近期由于IOS7的发布,所以应用的适配潮可谓是都搞的锣鼓喧天,甚是热闹,因此呢,因适配IOS7而产生的问题也是铺天盖地的卷来,所以了,我也从简单的状态栏适配开始,先研究了下关于状态栏的适配,特总结如下 ...

  7. Mac 下搭建vue开发环境

    tips:一定要有翻墙工具如lanter,另外要保证网速OK. 1. 首先需要安装homebrew liukingdeMBP:~ liuking$ /usr/bin/ruby -e "$(c ...

  8. 图解SQL的Join

    原文地址:http://coolshell.cn/articles/3463.html 对于SQL的Join,在学习起来可能是比较乱的.我们知道,SQL的Join语法有很多inner的,有outer的 ...

  9. linux中断处理-顶半部(top half)和底半部(bottom half) -转

    原文:http://rensanshi.blog.163.com/blog/static/21395510820136282224877/ 设备的中断会打断内核中进程的正常调度和运行,系统对更高吞吐率 ...

  10. C# 判断当前请求是GET、还是POST ?

    方法一: HttpContext.Current.Request.RequestType == "POST"   //当前请求为:POST 方法二: if(Request.Serv ...