OSS上的Object會有ETag標簽,ETag主要是用來判斷服務端數據是否存在變化。但是ETag不一定等同于文件的MD5值,所以不建議作為校驗數據一致性的依據。
如果需要校驗上傳到OSS的文件和本地文件是否一致,可以在上傳文件時攜帶文件的Content-MD5值。OSS會在接收文件時,將文件的MD5值和Content-MD5進行比對,兩者一致時才可以上傳成功,從而保證上傳數據的一致性。
以消息內容“0123456789”為例,以下詳細說明正確及錯誤計算該字符串的Content-MD5的方法。
正確計算示例
先計算MD5加密的二進制數組(128位)。
對該二進制數組進行base64編碼(而不是對32位字符串編碼)。
以Python為例:
>>> import base64,hashlib >>> hash = hashlib.md5() >>> hash.update("0123456789") #在Python 3中此處需要改為hash.update(b"0123456789")。 >>> base64.b64encode(hash.digest()) 'eB5eJF1ptWaXm4bijSPyxw=='
hash.digest(),計算出二進制數組(128位)。
>>> hash.digest() 'x\x1e^$]i\xb5f\x97\x9b\x86\xe2\x8d#\xf2\xc7'
錯誤計算示例
說明常見錯誤是直接對計算出的32位字符串進行base64編碼。
#hash.hexdigest(),計算得到可見的32位字符串編碼。 >>> hash.hexdigest() '781e5e245d69b566979b86e28d23f2c7' # 錯誤的MD5值進行base64編碼后的結果。 >>> base64.b64encode(hash.hexdigest()) 'NzgxZTVlMjQ1ZDY5YjU2Njk3OWI4NmUyOGQyM2YyYzc='
說明
部分Header中的參數(例如Content-MD5)需要加入到signature計算中,且Header和signature需保持一致,否則報錯SignatureDoesNotMatch。關于要簽名的Header,請參見簽名版本1。
文檔內容是否對您有幫助?