使用 HTML、javascript 和 jQuery 使用 Ajax Request 将图像上传到 Amazon s3
Uploading Image to Amazon s3 with HTML, javascript & jQuery with Ajax Request (No PHP)
我正在开发一个HTML,javascript和jQuery的网站。我想在 ajax 请求中将图像上传到 Amazon s3 服务器。没有这样的SDK可以在Javascript中集成s3。PHP SDK可用,但对我没有用。任何人都可以在javascript中为此提供解决方案吗?
根据本文文章,让 Amazon S3 和 CORS 使用 XMLHTTPObject 处理 js 和 html5。
1:CORS 只能从正确的 URL "http://localhost"工作。(file///xyz 会让你发疯)
2:确保你正确编译了策略和密钥 - 这是我的策略,这是你可以获得项目的链接,让你开始使用签名和策略 - 不要用你的秘密发布这个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);
这是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 = new XMLHttpRequest();
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);
}
帮助程序函数
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.");
}
然后是 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>
祝你快乐!
亚马逊只允许跨源资源共享,理论上它允许你的用户直接上传到S3,而无需使用你的服务器(和PHP)作为代理。
这是文档 -> http://docs.amazonwebservices.com/AmazonS3/latest/dev/cors.html
他们在告诉您如何在 S3 存储桶上启用它方面做得很好,但 iv 没有发现如何将数据从客户端获取到存储桶的实际 JavaScript 示例。
第一个发布CORS的人.js是一个传奇xD
您可以通过 AWS S3 Cogni 执行此操作,以尝试此处的此链接:
http://docs.aws.amazon.com/AWSJavaScriptSDK/guide/browser-examples.html#Amazon_S3
也试试这个代码
只需更改区域、身份池 ID 和您的存储桶名称
<!DOCTYPE html>
<html>
<head>
<title>AWS S3 File Upload</title>
<script src="https://sdk.amazonaws.com/js/aws-sdk-2.1.12.min.js"></script>
</head>
<body>
<input type="file" id="file-chooser" />
<button id="upload-button">Upload to S3</button>
<div id="results"></div>
<script type="text/javascript">
AWS.config.region = 'your-region'; // 1. Enter your region
AWS.config.credentials = new AWS.CognitoIdentityCredentials({
IdentityPoolId: 'your-IdentityPoolId' // 2. Enter your identity pool
});
AWS.config.credentials.get(function(err) {
if (err) alert(err);
console.log(AWS.config.credentials);
});
var bucketName = 'your-bucket'; // Enter your bucket name
var bucket = new AWS.S3({
params: {
Bucket: bucketName
}
});
var fileChooser = document.getElementById('file-chooser');
var button = document.getElementById('upload-button');
var results = document.getElementById('results');
button.addEventListener('click', function() {
var file = fileChooser.files[0];
if (file) {
results.innerHTML = '';
var objKey = 'testing/' + file.name;
var params = {
Key: objKey,
ContentType: file.type,
Body: file,
ACL: 'public-read'
};
bucket.putObject(params, function(err, data) {
if (err) {
results.innerHTML = 'ERROR: ' + err;
} else {
listObjs(); // this function will list all the files which has been uploaded
//here you can also add your code to update your database(MySQL, firebase whatever you are using)
}
});
} else {
results.innerHTML = 'Nothing to upload.';
}
}, false);
function listObjs() {
var prefix = 'testing';
bucket.listObjects({
Prefix: prefix
}, function(err, data) {
if (err) {
results.innerHTML = 'ERROR: ' + err;
} else {
var objKeys = "";
data.Contents.forEach(function(obj) {
objKeys += obj.Key + "<br>";
});
results.innerHTML = objKeys;
}
});
}
</script>
</body>
</html>
如果需要,您可以使用 github 链接
我希望它能帮助其他人:)
对于身份验证部分,
没有php代码,没有服务器,没有大的JS代码,除了下面;
您可以使用 AWS Cognito IdentityPoolId 作为凭证,减少代码但您需要创建 AWS Cognito IdetityPool 并附加策略,只需 s3 写入访问权限即可。
var IdentityPoolId = 'us-east-1:1..........';AWS.config.update({ 凭证:新 AWS。CognitoIdentityCredentials({ IdentityPoolId: IdentityPoolId }) });
- 使用图像数组列表的simplegallary.js显示适合桌面屏幕的图像
- 关联数组 - 使用图像滑块显示键值
- 使用图像而不是文本(script type=“text/javascript”)
- 2D物理引擎,使用图像模拟重力
- 使用图像映射调整大小器
- 是否可以使用图像数据设置画架命中区域
- 三个js性能如何使使用图像纹理更快
- 如何在jquery中使用图像ID获取图像位置
- 使用图像制作书籍阅读器[jquery]
- 如何使用图像更改下拉选择
- 使用图像显示和隐藏
- 使用图像提交表单问题
- 使用图像作为webkit滚动条 - -webkit-scrollbar-track-piece的最小高度
- Javascript/HTML5使用图像填充画布
- 使用图像最大宽度并保持高度比率以实现响应
- 使用图像 jQuery 切换
- 使用图像滚动达到页面中的最大内容,然后应该使用窗口百分比隐藏图像
- 如何在 CSS 中多个位置使用图像
- 如何使用图像加载.js与jribbble.js和砖石.js结合使用
- 在高图表制作者名单中使用图像