ng-file-upload Amazon s3 REST API授权错误

时间:2015-03-11 00:03:41

标签: php angularjs file-upload amazon-web-services amazon-s3

好的......我已经有一段时间了,而且我没有到达任何地方。无论我尝试什么,我都会继续从亚马逊返回相同的错误消息。

<Error>
  <Code>InvalidArgument</Code>
  <Message>Unsupported Authorization Type</Message>
  <ArgumentName>Authorization</ArgumentName>
  <ArgumentValue>Basic U1Q6</ArgumentValue>
  <RequestId>80B90936C37C0CEE</RequestId>
  <HostId>NphuQmN38ri6LvRAlpec8dSC2YwqOKD15ozInX7UmRPhFPZsGmFIghziNfzB/Y7o</HostId>
</Error>

我正在使用ng-file-upload(https://github.com/danialfarid/ng-file-upload)上传到S3。我已经按照文档说明并使用演示安装将文件成功上传到我的存储桶,因此我知道我的AWS Key和Secret Key是正确的。

我的控制器如下:

AWSs3 = {
        key:  'AWS-KEY-HERE',
        filename: file[0].name,
        fileSize: file[0].size,
        fileType: file[0].type,
        bucket: 'manual-attachments',
        acl: 'public-read',
        timestamp: timestamp
    }

$http({
        method: "post",
        url: "../api/manuals/s3",
        data: AWSs3
    }).success(function(data, status, headers, config){                                     
        file.upload = $upload.upload({
        url : 'https://bucket.s3.amazonaws.com/',
        method : 'POST',
        fields : {
                key: file[0].name,
                acl: AWSs3.acl,
                AWSAccessKeyId: AWSs3.key,
                policy: data.policy,
                signature: data.signature,
                "Content-Type"  : file.type === null || file.type === '' ? 'application/octet-stream' : file.type,
                filename: file[0].name
                },
                file : file,
            });

            file.upload.then(function(response) {
                $timeout(function() {
                    file.result = response.data;
                });
            }, function(response) {
                if (response.status > 0)
                    $scope.errorMsg = response.status + ': ' + response.data;
            });

            file.upload.progress(function(evt) {
                file.progress = Math.min(100, parseInt(100.0 * evt.loaded / evt.total));
                });

    }).error(function(data, status, headers, config){
        $log.info('{Error: '+data+'}');
        return false;
    });

现在用于生成策略和签名的PHP如下:

class S3 {
    public static $AWS_ACCESS_KEY           = "AWS-KEY";
    public static $AWS_SECRET_ACCESS_KEY    = "AWS-SECRET-KEY";

    public static function get_policy_and_signature( array $data )
    {
       $policy = self::get_policy_doc( $data );
       $signature = self::get_signature( $policy );

       if ( strpos($signature, '+') !== FALSE )
       {
           $data['timestamp'] = intval(@$data['timestamp']) + 1;
           return self::get_policy_and_signature( $data );
       }

       return '{"policy": "'.$policy.'", "signature":"'.$signature.'"}';
    }

    public static function get_policy_doc(array $data)
    {
       $now = strtotime(date("Y-m-d\TG:i:s"));
       $expire = date('Y-m-d\TG:i:s\Z', strtotime('+ 10 minutes', $now));

      return base64_encode(
           '{'.
               '"expiration": "'.$expire.'",'.
               '"conditions": '.
               '['.
                   '{"bucket": "'.$data['bucket'].'"},'.
                   '["starts-with", "$key", ""],'.
                   '{"acl": "public-read"},'.
                   '{"success_action_status": "201"},'.
                   '["starts-with", "$Content-Type", ""],'.
                   '["starts-with", "$filename", ""],'.
                   '["content-length-range",0,5242880]'.
               ']'.
           '}'
       );
    }

    public static function get_signature( $policy_doc ) {
       return base64_encode(hash_hmac(
           'sha1', $policy_doc, self::$AWS_SECRET_ACCESS_KEY, true
       ));
    }
}

http标题显示“授权:基本U1Q6”,这显然是个问题。对此的任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:0)

我是一个完全白痴!标题是由我自己的登录/授权脚本创建的。

我完全忘记了!一旦我解决了我没有问题。