博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
谈一次异步上传到又拍云的案例教程
阅读量:5927 次
发布时间:2019-06-19

本文共 1349 字,大约阅读时间需要 4 分钟。

  hot3.png

作者:白狼 出处: 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

网站静态文件存储在又拍云,之前上传是通过又拍云的的FORM API进行。

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

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

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

①、怎么实现异步上传

②、怎么上传到又 拍 云

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

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

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

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

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

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

function($){  //上传  $("#upload").on("change", function () {  //构造FormData对象并赋值    var formData = new FormData();    formData.append("policy", "//controller层传递过来upYun的policy配置");    formData.append("signature", "//controller层传递过来upyun的signature配置");    formData.append("file", $("#upload")[0].files[0]);    $.ajax({      url : "//处理上传的后端程序地址",      type : "POST",      data : formData,      processData : false,      contentType : false,      beforeSend: function () {        //可以做一些正在上传的效果      },      success : function(data) {        //data,我们这里是异步上传到后端程序所返回的图片地址      },      error : function(responseStr) {        console.log(responseStr);      }    });  });}($);

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

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

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

转载于:https://my.oschina.net/manks/blog/662157

你可能感兴趣的文章
大伟分析|如何提升网站收录
查看>>
机器视觉技术在薄膜检测系统的应用
查看>>
Android圆线按钮带进度显示
查看>>
回锅肉飘香,《Pokémon GO》再度成为最卖座的iPhone游戏
查看>>
使用JavaScript实现一个俄罗斯方块
查看>>
centos7 安装PostgreSQL
查看>>
移动信息化研究中心分析师吴勇:用尽洪荒之力,做一个优胜CIO
查看>>
FTP服务器无法获取远程列表解决办法
查看>>
达州市公安局探索IT运维新领域 北塔软件BTSO支撑“金盾工程”高效运转
查看>>
MyBatis Dynamic SQL 1.1.1 发布,生成动态 SQL 的框架
查看>>
Google Chrome浏览器中如何使用命令
查看>>
Linux 下安装pgbouncer
查看>>
「镁客·请讲」七奇智能姜志宏:一个由七个博士组成的传奇公司,要用虚拟人丰富我们的生活...
查看>>
美国政府否认“口头批准”超级高铁,然而马斯克没有任何损失
查看>>
AI创企推出双足机器人Cassie,可实现奔跑和行走
查看>>
xampp默认mysql密码设置,修改mysql的默认空密码
查看>>
Java基础教程:tutorialspoint-java
查看>>
PowerDesigner逆向工程从现有数据库生成PDM
查看>>
Chrome查看DNS状态提示:DNS pre-resolution and TCP pre-connection is disabled.
查看>>
AI设计师“鹿班”核心技术公开:如何1秒设计8000张海报?
查看>>