这两天修改公司小程序的一些功能,发现上传图片至OSS失败,便一直寻找出现了什么问题,最后发现是policy过时,更改后发现相应的signature也要改,由于须要特定的处理才能生成signature,当时好一顿查资料,最后算出signature,在这里作一下总结,也借签了一位做者的文章。https://segmentfault.com/a/11...git
首先,准备工做:
1.下载Base64.js,hmac.js,sha1.js,crypto.js相关算法点击。
2.建立一个用于计算的policy和signa的js文件,咱们只要输出结果便可。咱们起名为ceshi.js。
3.在ceshi.js引入咱们下载的4个算法文件。github
const Base64 = require('./Base64.js'); require('./hmac.js'); require('./sha1.js'); const Crypto = require('./crypto.js');
在ceshi.js算法
let date = new Date(); date.setHours(date.getHours() + 87677); let srcT = date.toISOString(); const policyText = { "expiration": srcT, //设置该Policy的失效时间 "conditions": [ ["content-length-range", 0, 5 * 1024 * 1024] // 设置上传文件的大小限制,5mb ] }; const policyBase64 = Base64.encode(JSON.stringify(policyText));
使用此js可计算出一个policy小程序
const accesskey = 'QSZ***98V1DW'; // 为了保密我作了处理,你们输入本身公司的accesskey便可。 const bytes = Crypto.HMAC(Crypto.SHA1, policyBase64, accesskey, { asBytes: true }); const signature = Crypto.util.bytesToBase64(bytes); console.log(policyBase64); console.log("myfunc...."); console.log(signature);
这样咱们即可计算出signature啦。segmentfault
ceshi.jsapp
const Base64 = require('./Base64.js'); require('./hmac.js'); require('./sha1.js'); const Crypto = require('./crypto.js'); function myfunc() { let date = new Date(); date.setHours(date.getHours() + 87677); let srcT = date.toISOString(); console.log(srcT); const policyText = { "expiration": srcT, //设置该Policy的失效时间 "conditions": [ ["content-length-range", 0, 5 * 1024 * 1024] // 设置上传文件的大小限制,5mb ] }; const policyBase64 = Base64.encode(JSON.stringify(policyText)); const accesskey = 'QSZYr****CIP98V1DW'; const bytes = Crypto.HMAC(Crypto.SHA1, policyBase64, accesskey, { asBytes: true }); const signature = Crypto.util.bytesToBase64(bytes); console.log(policyBase64); console.log("myfunc...."); console.log(signature); } module.exports.myfunc = myfunc;
4、调用ceshi.js
新建oss.jside
const ceshi = require('./ceshi.js'); var app = getApp() Page({ data: { }, onLoad: function (options) { ceshi.myfunc(); }, onReady: function () { }, onShow: function () { }, onHide: function () { }, onUnload: function () { }, onPullDownRefresh: function () { }, onReachBottom: function () { }, onShareAppMessage: function () { } })
以上是所有内容,感谢以前看过的类似文章,在此我本身作了相关总结,但愿能帮你们解决问题!谢谢!ui