更新时间:2024-11-13 GMT+08:00
如何指定Content-SHA256?(Node.js SDK)
上传对象和上传段支持携带x-obs-content-sha256头域,该头域值为请求消息体256-bit SHA256值转十六进制值,计算方式为Hex(SHA256Hash(<payload>),服务端会对携带此头域的请求计算其消息体的sha256值做校验(性能会有部分下降,在安全上推荐该算法),上传对象代码示例如下:
// 引入obs库
// 使用npm安装
var ObsClient = require('esdk-obs-nodejs');
var crypto = require('crypto');
var fs = require('fs');
// 使用源码安装
// var ObsClient = require('./lib/obs');
// 创建ObsClient实例
const obsClient = new ObsClient({
//推荐通过环境变量获取AKSK,这里也可以使用其他外部引入方式传入,如果使用硬编码可能会存在泄露风险。
//您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/intl/zh-cn/usermanual-ca/ca_01_0003.html
access_key_id: process.env.ACCESS_KEY_ID,
secret_access_key: process.env.SECRET_ACCESS_KEY,
//这里以中国-香港为例,其他地区请按实际情况填写
server: 'https://obs.ap-southeast-1.myhuaweicloud.com'
});
let filePath = 'D:\\example.xml'
let sha256 = crypto.createHash('sha256').update(fs.readFileSync(filePath, 'utf8'), 'utf8').digest('hex')
obsClient.putObject({
Bucket : 'bucketname',
Key : 'objectname',
SourceFile : filePath, // filePath为待上传的本地文件路径,需要指定到具体的文件名
ContentSha256 : sha256
}, (err, result) => {
if(err){
console.error('Error-->' + err);
}else{
console.log('Status-->' + result.CommonMsg.Status);
}
});
Node.js SDK 同时支持MD5与SHA256校验,在安全上更推荐使用SHA256算法
父主题: 常见问题(Node.js SDK)