本文版权归博客园和做者吴双本人共同全部.html
这是一个数据爆发的网络时代,你们习惯于浏览图文直观带给咱们的快速信息。大图片的存储和浏览常常会成为Web服务器的瓶颈。试想若是你的Web服务器依然将大量图片存储在其本地,而单页面主要的信息在于图片列表,在访问量增加后,必定会面临带宽、磁盘IO的瓶颈。继而形成Web服务器缓慢,而后又要作分布式文件存储,若是说本身实现简易的多文件服务器存储,能够移步到这:http://www.cnblogs.com/tdws/p/6231308.html ,若是说本身搭建稍微复杂一些的,甚至带处理图片大小,像素,压缩和缓存的话,你能够移步Zimg http://zimg.buaa.us/ 。web
我目前采用的是七牛云存储,主要青睐于其容量和CDN,还有图片瘦身问题的解决。既然解决的问题是Web服务器瓶颈,那么必定要使用JS SDK, 就是JS直接将文件直传给七牛云。ajax
为了使用JS直接传输文件到云存储,而非经过文件传输到web服务器,再由web服务器post文件到云存储,由于后者的方式,实在是太不尽人意了,并且太low。json
为了实现第一种方式,而且上传到云存储必需要携带认证的uptoken,才被认为是有权限的,因此不得不简单的修改一下源码,使得上传文件携带额外参数。跨域
本次修改,主要实现了UEditor多文件上传到云存储。单文件上传UEditor使用iframe的方式,目前尚未解决,不过有了多文件上传,单文件的也显得不那么重要了。其实实现的思路很简单了,找到全部的图片上传的代码,并在上传前从web服务器获取uptoken, 而后将其携带给ajax。七牛云存储
首先修改的是Ueditor 图片弹出框所引用的image.js 缓存
首先我将文件名给一个JS模拟生成的guid,而后请求Token,并设置为同步,在上传前,将token给到ajax请求所携带的data.这样一来上传的权限问题解决了。服务器
第二步就是修改配置,config.json,重点在于imageUrl和imageUrlPrefix.网络
第三步,我发如今多图上传的时候,ueditor并无使用个人imageUrl,而依然使用默认的本项目的路径。因此我经过搜索源码后找到位置,并作了以下修改:分布式
这个方法名称叫作getActionUrl,增长一行判断,若是action为uploadImage时,使用个人imageUrl,做为上传的路径,而不作其余任何拼接,直接返回imageUrl。
遇到的坑就是,七牛上传文件参数的key名称必定要是file。
另外百度富文本还要求了你上传后,服务起的返回格式,经过设置云存储的ReturnBody来实现
-------
2018-01-11更新:
若是你要支持截图的上传,还有一点须要注意,在上面第三步中,判断action的代码 改一下
if (action == "uploadimage" || action == "catchimage") {
return imageUrl;
}
------
找了很久,找到了这段单图上传的源码,你能够看见其经过iframe和构造form对象。因此我作的修改就是请求token,并在success回调函数中给其加一个input,并把token做为value给到input标签。
其上传的回调函数以下:抛出跨域异常的也正是这个位置,目前尚未解决,若是必定要实现的话,可能要参照下百度ueditor二次开发的文档。
其实也没有什么精彩的地方,不过相信使用云存储的人愈来愈多,必定还会有人须要,给本身个参考,也给他人一个参考。