当前位置:首页 > PHP教程 > php上传下载 > 列表

又拍云异步上传实例教程详解

发布:smiling 来源: PHP粉丝网  添加日期:2021-07-29 10:44:54 浏览: 评论:0 

这篇文章主要介绍了又拍云异步上传实例教程详解的相关资料,需要的朋友可以参考下,网站静态文件存储在又拍云,之前上传是通过又拍云的的FORM API进行。

当产品经理歪着脑袋走向你的时候,哎呀呀,这用户信息这里,上传要无刷新的效果了。

这他***,自己偷偷抱怨一会会,怎么搞喃?听说这家伙要一个好听的名字,异步上传,高大上档次挺像我的。

根据我们的观察,此处有两个重点:

①、怎么实现异步上传

②、怎么上传到又 拍 云

首先我们要实现异步上传,就需要利用js里面的FormData对象,据说,这家伙不支持ie6 7的,ie8就不太清楚了,据说哈,说错了不负责的。

不过喃,我们也不用考虑辣么多,前段时间都听说淘宝都要放弃ie6 7了,so 甭考虑辣么多了。ie6 7逮着ta估计都要骂ta小婊砸,竟然敢不支持我。

FormData是谁,这里就不多介绍了,可以自行百度。

我们先来看看view层怎么使用FormData这个小婊砸

<input type="file" accept="image/jpg,image/jpeg,image/png,image/gif" id="upload">

<input type="hidden" name="file">

如你所想,仅仅是一个input上传按钮和一个我们预留的准备接收图片地址的隐藏input

下面来看看JS是怎么愤怒的吧

  1. <script type="text/javascript"
  2. function($){ 
  3.  //上传 
  4.  $("#upload").on("change"function () { 
  5.  //构造FormData对象并赋值 
  6.   var formData = new FormData(); 
  7.   formData.append("policy""//controller层传递过来upYun的policy配置"); 
  8.   formData.append("signature""//controller层传递过来upyun的signature配置"); 
  9.   formData.append("file", $("#upload")[0].files[0]); 
  10.   $.ajax({ 
  11.    url : "//处理上传的后端程序地址"
  12.    type : "POST"
  13.    data : formData, 
  14.    processData : false
  15.    contentType : false
  16.    beforeSend: function () { 
  17.     //可以做一些正在上传的效果 
  18.    }, 
  19.    success : function(data) { 
  20.     //data,我们这里是异步上传到后端程序所返回的图片地址 
  21.    }, 
  22.    error : function(responseStr) { 
  23.     console.log(responseStr); 
  24.    } 
  25.   }); 
  26.  }); 
  27. }($); 
  28. </script> 

到此,我们已经实现了异步上传的前端代码,包括又拍云所需要的参数policy和signature

剩下的实现上传到又拍云就简单了,可以参考

https://github.com/upyun/php-sdk 进行处理

Tags: 又拍云异步上传

分享到: