私は AS3 マルチパート アップローダに取り組んでいます。署名を作成するために、このドキュメントhttp://docs.amazonwebservices.com/AmazonS3/latest/dev/index.html?RESTAuthentication.htmlを使用しています。これが私の例です:
リクエスト:
POST /btnOK.png?uploads HTTP/1.1
Referer: app:/Main.swf
Accept: text/xml, application/xml, application/xhtml+xml, text/html;q=0.9, text/plain;q=0.8, text/css, image/png, image/jpeg, image/gif;q=0.8, application/x-shockwave-flash, video/mp4;q=0.9, flv-application/octet-stream;q=0.8, video/x-flv;q=0.7, audio/mp4, application/futuresplash, */*;q=0.5
x-flash-version: 10,1,53,64
Date: Thu, 23 Jun 2011 09:03:18 GMT
Authorization: AWS accesskey:signature
Content-Type: image/png
User-Agent: Mozilla/5.0 (Windows; U; en-US) AppleWebKit/531.9 (KHTML, like Gecko) AdobeAIR/2.0.2
Host: bucketname.s3.amazonaws.com
Content-Length: 0
Connection: Keep-Alive
署名のないテキスト:
POST\n
\n
image/png\n
Thu, 23 Jun 2011 09:03:18 GMT
/bucketname/btnOK.png?uploads
そして、応答として次のエラーが表示されます: SignatureDoesNotMatch: The request signature we Calculated does not match the signature you provided. キーと署名方法を確認してください。
未署名のテキストに一部のヘッダーがありませんか? おそらくReferer、Acceptなどは署名されていないテキストにあるはずですか?
JavaScript で Amazon S3 Signature Tester ( http://aws.amazon.com/code/199 ) を使用していますが、同じ未署名のテキストを取得しています。多分問題は暗号化にありますか?as3crypto ライブラリを使用しています。そのためのAS3コードは次のとおりです。
private function generateSignature(datas:String, securityKey:String):String {
var sha:SHA1 = new SHA1();
var securityKeyArray:ByteArray = new ByteArray();
securityKeyArray.writeUTFBytes(escape(securityKey));
sha.hash(securityKeyArray);
var hmac:HMAC = new HMAC(sha);
var datasArray:ByteArray = new ByteArray();
datasArray.writeUTFBytes(escape(datas));
var signatureArray:ByteArray = new ByteArray();
signatureArray = hmac.compute(securityKeyArray, datasArray);
return Base64.encodeByteArray(signatureArray);
}
助けてください!ありがとう!