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

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

(一)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. HTTP协议请求篇

    http协议的基本概念 超文本传输协议(HTTP,HyperText Transfer Protocol)是互联网上应用最为广泛的一种网络协议.是工作在tcp/ip协议基础上的,所有的WWW文件都必须 ...

  2. PHP面向对象之继承的基本思想

    图例 概念和说明 代码展示 <?php header('content-type:text/html;charset=utf-8'); //学生考试系统 class Student{ publi ...

  3. unity3d入门 Demo 学习记录

    闲来学习一下 unity3d 的Demo,记录如下. 官方 Demo,名字为 Roll-A-Ball,如图 场景比较简单,包含地面.玩家精灵.主摄像机.墙壁.可拾取的方块.分数为示 text.平行光源 ...

  4. 警告(alert 消息对话框) 如果你不点击“确定”,就不能对网页做任何操作,这个小窗口就是使用alert实现的

    警告(alert 消息对话框) 我们在访问网站的时候,有时会突然弹出一个小窗口,上面写着一段提示信息文字.如果你不点击"确定",就不能对网页做任何操作,这个小窗口就是使用alert ...

  5. Extjs & Ext.net中的一些属性

    Extjs & Ext.Net 弹出整个浏览器对话框的方法 top.Ext.Msg.alert("值"); top.Ext.Msg.confirm("值" ...

  6. nginx压力测试webbench

    下载压力测试工具webbench wget http://home.tiscali.cz/~cz210552/distfiles/webbench-1.5.tar.gz 安装依赖包 yum -y in ...

  7. leetcode146周赛-1131-绝对值表达式的最大值

    题目描述: class Solution: def maxAbsValExpr(self, arr1, arr2) -> int: def function(s1,s2): result1=[] ...

  8. Data Dependency

    https://en.wikipedia.org/wiki/Data_dependency (There’s some misleading expression on the flow/data d ...

  9. 洛谷P5104 红包发红包

    题目链接: P5104 题目分析: 题目和\(n\)是没什么关系的,因为是\(n\)个人抢,其实不一定抢完 其实很显然--就是求一个连续型随机变量的期望 首先设一个随机变量\(X\),表示第一个人拿到 ...

  10. iOS之CAGradientLayer属性简介和使用

    1.CAGradientLayer简介 CAGradientLayer用于制作背景图层的颜色渐变,也就是颜色梯度!相关属性简介: #import <QuartzCore/CALayer.h> ...