阿里云盘(阿里云盘网页版)
上传、预览、下载图片是app常用的功能之一,一般的做法是建立一个图片存储服务器,再开发一个接收前端上传文件的后端服务,接收到前端上传的图片文件,然后再调用存储服务器的接口完成图片文件的存储。
现在阿里云提供了对象存储云服务,非常方便APP直接将图片等文件上传上去,并提供了多种浏览、下载的方式,不仅操作简单、而且效率高、速度快,本文介绍三种使用方式,希望能够让工程师少走弯路。
传统模式
这种方式只是把OSS作为文件存储体替代了自建存储器,上传逻辑和路径还是和传统的方式一致,后端服务给前端提供上传接口,在收到前端上传的文件后,再调用阿里云的OSS SDK的API将文件上传到阿里云的OSS存储桶中。
上传流程
详细说明及相关代码请参考《云平台对象存储OSS》
直接表单方式
这种方式更加的便捷、快速,无需开发接收后端服务,而是前端直接将文件上传到OSS,这种方式就要求前端按照约定的参数访问OSS API,为了安全起见要按照阿里云SDK的方式生成相应的签名并提供给前端。
FORM表单直接上传流程
这里要求提前生成签名串,生成算法如下:
package aliyun;import aliyun.pojo.ResultData;import aliyun.pojo.SignatureData;import com.alibaba.fastjson.JSONObject;import org.apache.commons.codec.binary.Base64;public class Controller { private final static String POLICY="{\\"expiration\\":\\"2025-12-31T23:59:59Z\\",\\"conditions\\":[[\\"content-length-range\\",0,104857600]]}"; private String accessKeySecret = System.getenv; public String signatureCode throws Exception { ResultData resultData=new ResultData; //约束规则 String encodePolicy = new String)); // 生成签名。 String signatureCom = com.aliyun.oss.common.auth.ServiceSignature.create.computeSignature; SignatureData signatureData=new SignatureData; resultData.setData; return JSONObject.toJSONString; }}
其中:POLICY定义了上传有效时间和文件大小约束,签名要用到阿里云账号的Access Key Secret。这里的签名是有时效性的,有效期内不会改变,如果对安全要求很高,可以将该签名过程作为服务发布,让前端每次在上传的时候调用服务获取实时的签名数据。
前端form表单的构成如下:
<div id="upload"> <form action="http://mybucket.oss-cn-beijing.aliyuncs.com" method="post" enctype="multipart/form-data"> <p>阿里云AccessKeyID:<input type="text" name="OSSAccessKeyId" value="LTAI8N5***XX8cr"></p> <p>约束规则base64:<input type="text" name="policy" value='eyJleHBpcmF0aW9uI*********zMVQyMzo1OTo1OVoiLCJjb25kaXRpb25zIjpbWyJjb250ZW50LWxlbmd0aC1yYW5nZSIsMCwxMDQ4NTc2MDBdXX0='></p> <p>约束规则签名:<input type="text" name="Signature" value="pgxE8VnN8kSJEWz*****QV7uBE="></p> <p>OSS存储文件名:<input type="text" name="key" value="upload/lee.jpg"></p> <p>选择上传文件:<input name="file" type="file" id="file"></p> <input name="submit" value="上传" type="submit"> </form></div>
其中:action是你账号下OSS存储桶的endpoint URL,OSSAccessKeyId是你账号下的AccessKey ID,policy是对上传规则约束的base64编码,Signature就是对policy的签名结果,key是存储到你指定bucket的目录和文件名。
ajax方式
通过这种方式可以不刷新页面完成文件直接上传到OSS,建议采用plupload.js插件实现。
<!DOCTYPE html><html><head><meta http-equiv="content-type" content="text/html; charset=UTF-8"/><title>OSS web直传</title><link rel="stylesheet" type="text/css" href="style.css"/><meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"></head><body><h2>OSS web直传---直接在JS签名</h2><ol><li>基于plupload封装 </li><li>支持html5,flash,silverlight,html4 等协议上传</li><li>可以运行在PC浏览器,手机浏览器,微信</li><li>可以选择多文件上传</li><li>显示上传进度条</li><li>可以控制上传文件的大小</li><li>蕞关键的是,让你10分钟之内就能移植到你的系统,实现以上牛逼的功能!</li><li>注意一点,bucket必须设置了Cors;" class='btn'>选择文件</a><a id="postfiles" href="javascript:void;" class='btn'>开始上传</a></div><pre id="console"></pre><p> </p></body><script type="text/javascript" src="lib/plupload-2.1.2/js/plupload.full.min.js"></script><script type="text/javascript" src="upload.js"></script></html>
upload.js代码如下:
host = 'http://mybucket.oss-cn-beijing.aliyuncs.com';accessid= 'LTAI8N***mXX8cr';signature = "pgxE8V******Wz1jKv7cQV7uBE=";policyBase64 = "eyJleHBpcmF0aW9uIjoiMjAyNS0xMi0zMVQyMzo1OTo1OVoiLCJjb25kaXRpb25zIjpbWyJjb250ZW50LWxlbmd0aC1yYW5nZSIsMCwxMDQ4NTc2MDBdXX0=";g_dirname = ''g_object_name = ''g_object_name_type = ''now = timestamp = Date.parse) / 1000; function check_object_radio { var tt = document.getElementsByName; for { if { g_object_name_type = tt[i].value; break; } }}function get_dirname{ dir = document.getElementById.value; if != dir.length - 1) { dir = dir + '/' } //alert g_dirname = dir}function random_string { len = len || 32; var chars = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678'; var maxPos = chars.length; var pwd = ''; for { pwd += chars.charAt * maxPos)); } return pwd;}function get_suffix { pos = filename.lastIndexOf suffix = '' if { suffix = filename.substring } return suffix;}function calculate_object_name{ if { g_object_name += "${filename}" } else if { suffix = get_suffix g_object_name = g_dirname + random_string + suffix } return ''}function get_uploaded_object_name{ if { tmp_name = g_object_name tmp_name = tmp_name.replace; return tmp_name } else if { return g_object_name }}function set_upload_param{ g_object_name = g_dirname; if { suffix = get_suffix calculate_object_name } new_multipart_params = { 'key' : g_object_name, 'policy': policyBase64, 'OSSAccessKeyId': accessid, 'success_action_status' : '200', //让服务端返回200,不然,默认会返回204 'signature': signature, }; up.setOption; up.start;}var uploader = new plupload.Uploader,flash_swf_url : 'lib/plupload-2.1.2/js/Moxie.swf',silverlight_xap_url : 'lib/plupload-2.1.2/js/Moxie.xap', url : 'http://oss.aliyuncs.com',init: {PostInit: function {document.getElementById.innerHTML = '';document.getElementById.onclick = function { set_upload_param; return false;};},FilesAdded: function {plupload.each {document.getElementById.innerHTML += '<div id="' + file.id + '">' + file.name + ' + ')<b></b>'+'<div class="progress"><div class="progress-bar" style="width: 0%"></div></div>'+'</div>';});},BeforeUpload: function { check_object_radio; get_dirname; set_upload_param; },UploadProgress: function {var d = document.getElementById;d.getElementsByTagName[0].innerHTML = '<span>' + file.percent + "%</span>"; var prog = d.getElementsByTagName[0];var progBar = prog.getElementsByTagName[0]progBar.style.width= 2*file.percent+'px';progBar.setAttribute;},FileUploaded: function { if { document.getElementById.getElementsByTagName[0].innerHTML = 'upload to oss success, object name:' + get_uploaded_object_name; } else { document.getElementById.getElementsByTagName[0].innerHTML = info.response; } },Error: function {document.getElementById.appendChild);}}});uploader.init;
其中:host为OSS存储桶endpoint地址、accessid为阿里云账号ID、signature为后端生成的签名、policyBase64为规则json串的base64编码
访问上传的文件
有多种方式可以查看你上传的文件,详细操作见阿里云OSS操作手册。这里只说明一种直接通过URL访问的方式。
针对该bucket设置为开通“静态页面”、权限管理设置为“公共可读”、防盗链设置“referer”等安全选项,然后就可以通过类似
http://mybucket.oss-cn-beijing.aliyuncs.com/upload/lee
的方式访问你上传的图片等文件了。
海外精品引流脚本–最强海外引流
查看演示与获取方案
读完本篇后,可通过下方入口查看演示视频、联系客服或访问主站。

