当前位置:首页 > 实用技巧 >

怎么将照片弄到云服务上面(云服务的照片怎么导入到手机)

来源:原点资讯(www.yd166.com)时间:2023-07-31 13:37:53作者:YD166手机阅读>>

上传、预览、下载图片是app常用的功能之一,一般的做法是建立一个图片存储服务器,再开发一个接收前端上传文件的后端服务,接收到前端上传的图片文件,然后再调用存储服务器的接口完成图片文件的存储。

现在阿里云提供了对象存储云服务(OSS),非常方便APP直接将图片等文件上传上去,并提供了多种浏览、下载的方式,不仅操作简单、而且效率高、速度快,本文介绍三种使用方式,希望能够让工程师少走弯路。

传统模式

这种方式只是把OSS作为文件存储体替代了自建存储器,上传逻辑和路径还是和传统的方式一致,后端服务给前端提供上传接口,在收到前端上传的文件后,再调用阿里云的OSS SDK的API将文件上传到阿里云的OSS存储桶中。

怎么将照片弄到云服务上面,云服务的照片怎么导入到手机(1)

上传流程

详细说明及相关代码请参考

直接表单方式

这种方式更加的便捷、快速,无需开发接收后端服务,而是前端直接将文件上传到OSS,这种方式就要求前端按照约定的参数访问OSS API,为了安全起见要按照阿里云SDK的方式生成相应的签名并提供给前端。

怎么将照片弄到云服务上面,云服务的照片怎么导入到手机(2)

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("ACCESS_SECRET_CODE"); public String signatureCode(int times) throws Exception { ResultData resultData=new ResultData(); //约束规则 String encodePolicy = new String(Base64.encodeBase64(POLICY.getBytes())); // 生成签名。 String signatureCom = com.aliyun.oss.common.auth.ServiceSignature.create().computeSignature(accessKeySecret, encodePolicy); SignatureData signatureData=new SignatureData(encodePolicy,signatureCom); resultData.setData(signatureData); return JSONObject.toJSONString(resultData); } }

其中: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编码(这里千万不能直接使用你定义的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(Post打勾),不然没有办法上传</li> <li>注意一点,把upload.js 里面的host/accessid/accesskey改成您上传所需要的信息即可</li> <li>此方法是直接在前端签名,有accessid/accesskey泄漏的风险, 线上生产请使用后端签名例子<a href="https://help.aliyun.com/document_detail/oss/practice/pc_web_upload/js_php_upload.html">点击查看详细文档</a></li> </ol> <br> <form name="theform"> <input type="radio" name="myradio" value="local_name" checked=true/> 上传文件名字保持本地文件名字 <input type="radio" name="myradio" value="random_name" /> 上传文件名字是随机文件名 <br/> 上传到指定目录:<input type="text" id='dirname' placeholder="如果不填,默认是上传到根目录" size=50> </form> <h4>您所选择的文件列表:</h4> <div id="ossfile">你的浏览器不支持flash,Silverlight或者HTML5!</div> <br/> <div id="container"> <a id="selectfiles" href="javascript:void(0);" class='btn'>选择文件</a> <a id="postfiles" href="javascript:void(0);" 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(new Date()) / 1000; function check_object_radio() { var tt = document.getElementsByName('myradio'); for (var i = 0; i < tt.length ; i ) { if(tt[i].checked) { g_object_name_type = tt[i].value; break; } } } function get_dirname() { dir = document.getElementById("dirname").value; if (dir != '' && dir.indexOf('/') != dir.length - 1) { dir = dir '/' } //alert(dir) g_dirname = dir } function random_string(len) {   len = len || 32;   var chars = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678';   var maxPos = chars.length;   var pwd = '';   for (i = 0; i < len; i ) {   pwd = chars.charAt(Math.floor(Math.random() * maxPos)); } return pwd; } function get_suffix(filename) { pos = filename.lastIndexOf('.') suffix = '' if (pos != -1) { suffix = filename.substring(pos) } return suffix; } function calculate_object_name(filename) { if (g_object_name_type == 'local_name') { g_object_name = "${filename}" } else if (g_object_name_type == 'random_name') { suffix = get_suffix(filename) g_object_name = g_dirname random_string(10) suffix } return '' } function get_uploaded_object_name(filename) { if (g_object_name_type == 'local_name') { tmp_name = g_object_name tmp_name = tmp_name.replace("${filename}", filename); return tmp_name } else if(g_object_name_type == 'random_name') { return g_object_name } } function set_upload_param(up, filename, ret) { g_object_name = g_dirname; if (filename != '') { suffix = get_suffix(filename) calculate_object_name(filename) } new_multipart_params = { 'key' : g_object_name, 'policy': policyBase64, 'OSSAccessKeyId': accessid, 'success_action_status' : '200', //让服务端返回200,不然,默认会返回204 'signature': signature, }; up.setOption({ 'url': host, 'multipart_params': new_multipart_params }); up.start(); } var uploader = new plupload.Uploader({ runtimes : 'html5,flash,silverlight,html4', browse_button : 'selectfiles', container: document.getElementById('container'), 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('ossfile').innerHTML = ''; document.getElementById('postfiles').onclick = function() { set_upload_param(uploader, '', false); return false; }; }, FilesAdded: function(up, files) { plupload.each(files, function(file) { document.getElementById('ossfile').innerHTML = '<div id="' file.id '">' file.name ' (' plupload.formatSize(file.size) ')<b></b>' '<div class="progress"><div class="progress-bar" style="width: 0%"></div></div>' '</div>'; }); }, BeforeUpload: function(up, file) { check_object_radio(); get_dirname(); set_upload_param(up, file.name, true); }, UploadProgress: function(up, file) { var d = document.getElementById(file.id); d.getElementsByTagName('b')[0].innerHTML = '<span>' file.percent "%</span>"; var prog = d.getElementsByTagName('div')[0]; var progBar = prog.getElementsByTagName('div')[0] progBar.style.width= 2*file.percent 'px'; progBar.setAttribute('aria-valuenow', file.percent); }, FileUploaded: function(up, file, info) { if (info.status == 200) { document.getElementById(file.id).getElementsByTagName('b')[0].innerHTML = 'upload to oss success, object name:' get_uploaded_object_name(file.name); } else { document.getElementById(file.id).getElementsByTagName('b')[0].innerHTML = info.response; } }, Error: function(up, err) { document.getElementById('console').appendChild(document.createTextNode("\nError xml:" err.response)); } } }); uploader.init();

其中:host为OSS存储桶endpoint地址、accessid为阿里云账号ID、signature为后端生成的签名、policyBase64为规则json串的base64编码

访问上传的文件

有多种方式可以查看你上传的文件,详细操作见阿里云OSS操作手册。这里只说明一种直接通过URL访问的方式。

针对该bucket设置为开通“静态页面”、权限管理设置为“公共可读”、防盗链设置“referer”等安全选项,然后就可以通过类似

http://mybucket.oss-cn-beijing.aliyuncs.com/upload/lee

的方式访问你上传的图片等文件了。

栏目热文

怎么把云服务里面的照片导出(怎么将云服务的照片导入)

怎么把云服务里面的照片导出(怎么将云服务的照片导入)

才知道!原来把手机里照片导出到U盘这么简单,再也不怕储存小了在这个数字化时代,手机已经成为我们生活中不可或缺的一部分。我...

2023-07-31 13:49:40查看全文 >>

如何把照片存到云服务(怎么把照片弄进云服务里)

如何把照片存到云服务(怎么把照片弄进云服务里)

很多人都试过手机内存不够了,要清理一下相片或视频,但是选来选去我都不想删掉都很喜欢啊,该怎么办呢?没关系,今天我们来分享...

2023-07-31 14:16:04查看全文 >>

怎么将云服务的照片导入(云服务的照片怎么导入电脑)

怎么将云服务的照片导入(云服务的照片怎么导入电脑)

很多小伙伴都有使用iCloud储存照片的习惯,不过往往iCloud的储存空间并不是那么够用。如果想要将iCloud中的照...

2023-07-31 13:43:35查看全文 >>

怎么打开云服务里的照片(怎么找出云服务里的照片)

怎么打开云服务里的照片(怎么找出云服务里的照片)

小伙伴们是否有碰到过手机意外丢失的情况呢?如果手机数据意外丢失,是不是整个人瞬间都不好了。这个时候OPPO A92s的云...

2023-07-31 13:36:10查看全文 >>

怎么把照片放到云服务里面(怎么把云服务的照片导出)

怎么把照片放到云服务里面(怎么把云服务的照片导出)

平时用手机,经常会遇到手机空间不足,想要将手机上的照片、联系人、信息、便签等备份出来以节省手机空间,或者是换新手机导入资...

2023-07-31 13:34:31查看全文 >>

怎么用云服务储存照片(云服务能储存照片吗)

怎么用云服务储存照片(云服务能储存照片吗)

为了长久保存家庭照片和视频文件,并且方便查看,您可以考虑以下几种方法:1. 云存储:将照片和视频上传至云存储服务,如iC...

2023-07-31 14:06:11查看全文 >>

照片存到云服务怎么移出(手机上的照片怎样存到云服务里)

照片存到云服务怎么移出(手机上的照片怎样存到云服务里)

每个手机里都有云备份,云备份空间一般不大,如果平时不习惯把照片、视频等备份到云备份的,可以关掉云备份:1、打开手机的[设...

2023-07-31 13:47:51查看全文 >>

云服务中的照片怎样转到相册去(怎么从云服务里把照片移到相册)

云服务中的照片怎样转到相册去(怎么从云服务里把照片移到相册)

近年来 iOS 跟 Android 的联系越来越多,虽然 iOS 14 隐 私标签功能让苹果和谷歌一度陷入僵局,上周谷歌...

2023-07-31 13:45:27查看全文 >>

云服务怎么把照片保存到相册里(云服务怎么把相片导入到相册)

云服务怎么把照片保存到相册里(云服务怎么把相片导入到相册)

现在是移动互联网时代,手机的地位也尤为突出,工作和生活中我们都要到它。不过一旦发生储存不足,手机意外丢失,甚至数据泄露,...

2023-07-31 14:11:56查看全文 >>

文档排行