php图片上传转发上传,[前后端的故事]PHP是如何上传图片的

近期一些朋友,在做上传图片这一块的时候卡住了。

有个朋友说,我已经浪费了一天时间在做一块,根本不知道怎么做。

这种时候我必须挺身而出。

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

(一)form表单上传

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

前端的代码:

action 请求的后端方法

enctype="multipart/form-data" 在使用包含文件上传控件的表单时,必须使用该值。

后端的代码:

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($tempFile, $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+。

原生的XMLHttpRequest 实现

前端的代码:

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("添加失败");

}

}

}

}

}

后端代码:

如方法一,不变。

JQuery + FormData 实现

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

前端代码:

指定文件名:

上传文件:

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);

}

});

}

后端代码:

如方法一,不变。

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

总结

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值