1、准备一个a.txt文档。内容随意。 2、OBS服务支持基于浏览器的POST上传对象请求,此类请求的签名信息通过表单的方式上传。 请参考网址?https://support.huaweicloud.com/api-obs/obs_04_0012.html POST上传对象:首先,创建一个安全策略,指定请求中需要满足的条件,比如:桶名、对象名前缀;然后,创建一个基于此策略的签名,需要签名的请求表单中必须包含有效的signature和policy;最后,创建一个表单将对象上传到桶中。 签名的计算过程如下: (1)对policy内容进行UTF-8编码。 (2)对第一步的结果进行Base64编码。 (3)使用SK对第二步的结果进行HMAC-SHA1签名计算。 (4)对第三步的结果进行Base64编码,得到签名。 StringToSign = Base64( UTF-8-Encoding-Of( policy ) ) Signature = Base64( HMAC-SHA1( YourSecretAccessKeyID, StringToSign ) ) 3、复制下面python代码
import base64 import hashlib import hmac import urllib.parse
def sign_in_post(sk, policy): string_to_sign = base64.b64encode(policy.encode('UTF-8')) print('string_to_sign:\n', string_to_sign)
hashed = hmac.new(sk.encode('UTF-8'), string_to_sign, hashlib.sha1) sign = base64.b64encode(hashed.digest()).decode('UTF-8') print('sign:\n', sign)
return sign
sk = '此处省略sk实际内容' policy = '''{"expiration": "2021-09-02T12:00:00.000Z", "conditions":[ {"bucket":"bucket-guxiaobei"}, {"key":"a.txt"} ] }'''
sign_in_post(sk,policy) |
4、在pycharm里运行,可以得到policy和signature。 (1)sk为你实际Secret Access Key内容。 (2)expiration为过期时间。 (3)bucket为你的桶名。 (4)key为期望上传对象的名字。 5、打开postman软件,选择POST方法。 (1)地址栏填入http://?访问域名?/?。我写的是http://bucket-guxiaobei.obs.cn-north-4.myhuaweicloud.com/ (2)其他Headers参考下图。 注意:postman有一些自动生成的头信息auto-generated headers,并不都是必须项。 6、点击“Body”。类型选form-data。Select File,选择前面准备好的a.txt (1)key为期望上传对象的名字。 (2)AccessKeyId是我的Access Key Id值。 (3)signature是刚计算出来的签名。 (4)policy是刚计算出来的策略。 (5)file是实际上传的文件。约束条件:此参数必须为最后一个参数,否则此参数之后的参数会被丢弃;一个请求中只能含有一个file参数。 7、点击send,返回状态Status 204 No Content。 8、返回华为云OBS控制台。可以看到a.txt已经上传。点击下载。 8、完成txt上传。 注意:OBS并不强制本地文件名和OBS桶的期待文件名,保持一致。你可以本地a.txt,上传为b.txt。 |