使用带有Ajax请求的HTML,javascript和jQuery将图像上传到Amazon s3(无PHP)

Swa*_*mbe 61 javascript jquery html5 amazon-s3

我正在开发一个HTML,javascript和jQuery的网站.我想在ajax请求中将图像上传到amazon s3服务器.没有这样的SDK可以在Javascript中集成s3.PHP SDK可用,但对我没用.任何人都可以在JavaScript中提供解决方案吗?

fin*_*ino 121

根据本文的文章,使用XMLHTTPObject让Amazon S3和CORS在js和html5上工作.

1:CORS仅适用于正确的URL" http:// localhost ".(文件/// xyz会让你发疯)

2:确保你已经正确编译了POLICY和Secret - 这是我的政策,这是你可以获得项目的链接,让你开始使用签名和政策 - 不要用你的秘密EVER发布这个JS!

POLICY_JSON = { "expiration": "2020-12-01T12:00:00.000Z",
            "conditions": [
            {"bucket": this.get('bucket')},
            ["starts-with", "$key", ""],
            {"acl": this.get('acl')},                           
            ["starts-with", "$Content-Type", ""],
            ["content-length-range", 0, 524288000]
            ]
          };


    var secret = this.get('AWSSecretKeyId');
    var policyBase64 = Base64.encode(JSON.stringify(POLICY_JSON));
    console.log ( policyBase64 )

    var signature = b64_hmac_sha1(secret, policyBase64);
    b64_hmac_sha1(secret, policyBase64);
    console.log( signature);
Run Code Online (Sandbox Code Playgroud)

这是JS代码

function uploadFile() {

    var file = document.getElementById('file').files[0];
    var fd = new FormData();

    var key = "events/" + (new Date).getTime() + '-' + file.name;

    fd.append('key', key);
    fd.append('acl', 'public-read'); 
    fd.append('Content-Type', file.type);      
    fd.append('AWSAccessKeyId', 'YOUR ACCESS KEY');
    fd.append('policy', 'YOUR POLICY')
    fd.append('signature','YOUR SIGNATURE');

    fd.append("file",file);

    var xhr = getXMLHTTPObject();

    xhr.upload.addEventListener("progress", uploadProgress, false);
    xhr.addEventListener("load", uploadComplete, false);
    xhr.addEventListener("error", uploadFailed, false);
    xhr.addEventListener("abort", uploadCanceled, false);

    xhr.open('POST', 'https://<yourbucket>.s3.amazonaws.com/', true); //MUST BE LAST LINE BEFORE YOU SEND 

    xhr.send(fd);
  }
Run Code Online (Sandbox Code Playgroud)

助手功能

function uploadProgress(evt) {
    if (evt.lengthComputable) {
      var percentComplete = Math.round(evt.loaded * 100 / evt.total);
      document.getElementById('progressNumber').innerHTML = percentComplete.toString() + '%';
    }
    else {
      document.getElementById('progressNumber').innerHTML = 'unable to compute';
    }
  }

  function uploadComplete(evt) {
    /* This event is raised when the server send back a response */
    alert("Done - " + evt.target.responseText );
  }

  function uploadFailed(evt) {
    alert("There was an error attempting to upload the file." + evt);
  }

  function uploadCanceled(evt) {
    alert("The upload has been canceled by the user or the browser dropped the connection.");
  }
Run Code Online (Sandbox Code Playgroud)

然后是HTML表单

 <form id="form1" enctype="multipart/form-data" method="post">
<div class="row">
  <label for="file">Select a File to Upload</label><br />
  <input type="file" name="file" id="file" onchange="fileSelected()"/>
</div>
<div id="fileName"></div>
<div id="fileSize"></div>
<div id="fileType"></div>
<div class="row">
  <input type="button" onclick="uploadFile()" value="Upload" />
</div>
<div id="progressNumber"></div>
Run Code Online (Sandbox Code Playgroud)

快乐的CORSING!

  • 刚刚发现这篇文章详细解释了AWS上传表单的解剖结构:http://aws.amazon.com/articles/1434 (4认同)
  • 如果作者考虑在第一个代码示例中解释他们正在做什么,那么这篇文章肯定可以改进.引用的链接在Ruby,Java和Python中有类似的示例.最大的问题是,作者忽略了说哪些库用于Base64和Crypto.(标准节点加密应该工作) (3认同)
  • @fino我很困惑 - 要么你发布你的AWS秘密(不鼓励),要么签署表单服务器端?你提倡哪些,或者我错过了什么? (3认同)
  • var xhr = getXMLHTTPObject();应该是var xhr = new XMLHttpRequest();好的脚本,可惜我们仍然需要对IE8和9使用糟糕的iframe (3认同)
  • 嗨伙计.这看起来就像我正在寻找上传到我的S3存储桶.然而,我对第一部分感到难过(具有讽刺意味的是,其余部分看起来很直接).对于S3而言,我是一个全新的东西,说实话,我只是不知道如何处理POLICY_JSON代码.简而言之:我在哪里放这个? (2认同)
  • 您使用什么文件定义Base64? (2认同)
  • “ b64_hmac_sha1”来自哪里? (2认同)

luk*_*onn 7

亚马逊只允许跨源资源共享,理论上它允许您的用户直接上传到S3,而无需使用您的服务器(和PHP)作为代理.

继承人的文档 - > http://docs.amazonwebservices.com/AmazonS3/latest/dev/cors.html

他们很好地告诉你如何在S3存储桶上启用它,但iv没有发现如何从客户端到存储桶获取数据的实际javascript示例.

发布CORS.js的第一个人是传奇xD


小智 5

以下是使用CORS和javascript http://cotag.github.com/Condominios/在Amazon S3上上载可恢复文件的示例