Google云端存储Javascript使用情况

che*_*o_c 7 javascript cloud storage json google-cloud-storage

我正在尝试使用JSON API将图像上传到Google云端存储上的存储桶中,使用Javascript示例: Api Javascript示例

我可以上传图片,但它要求我登录我的谷歌帐户.

示例有一个授权按钮,据我所知,它管理OAuth凭据.

    function checkAuth() {
  gapi.auth.authorize({
    client_id: clientId,
    scope: scopes,
    immediate: true
  }, handleAuthResult);
}
Run Code Online (Sandbox Code Playgroud)

问题是:

我想在没有弹出屏幕的情况下进行身份验证,这意味着无需登录Google.因为我的客户端不知道电子邮件或密码,我希望它是自动的.

我怎样才能做到这一点?

谢谢!

----------------------------- UPDATE --------------------

因此,按照布兰登的回答,我做了以下事情:

我创建了我的政策文件并签名如下:

var http = require('http');
var fs = require('fs');
var crypto = require('crypto');
var express = require('express');
var app = express();
var p12ToPem = require("./node_modules/p12-to-pem/p12ToPem.js");
var p12File = fs.readFileSync("./KEY.p12");
var pemKey = p12ToPem(p12File, "notasecret");
 var policyJson={"expiration": "2050-06-16T11:11:11Z",
"conditions": [["starts-with", "$key", "" ],
{"acl": "bucket-owner-read" },
{"bucket": "my-bucket'name"},
{"success_action_redirect":"http://www.example.com/success_notification.html" },
 ["eq", "$Content-Type", "image/jpeg" ],
 ["content-length-range", 0, 1000000]
 ]
};
var policyJson64 = new Buffer(''+policyJson).toString('base64');
var sign = crypto.createSign('RSA-SHA256');
sign.update(policyJson64);
var sig = sign.sign(pemKey, 'base64')
console.log("policyJson64:"+policyJson64);
console.log("sig:"+sig);
Run Code Online (Sandbox Code Playgroud)

我的帖子形式如下:

  <form action="http://my-bucket-name.storage.googleapis.com" method="post" enctype="multipart/form-data">
<input type="text" name="key" value="">
<input type="hidden" name="bucket" value="my-bucket-name">
<input type="hidden" name="Content-Type" value="image/jpeg">
<input type="hidden" name="GoogleAccessId" value="884257827820-so77htet9tafrcjjp83m7api9lh12qsn@developer.gserviceaccount.com">
<input type="hidden" name="acl" value="bucket-owner-read">
<input type="hidden" name="success_action_redirect" value="http://www.example.com/success_notification.html">
<input type="hidden" name="policy" value="DONT KNOW WHAT TO PUT HERE">
<input type="hidden" name="signature" value="NEITHER HERE">
<input name="file" type="file">
<input type="submit" value="Upload">
Run Code Online (Sandbox Code Playgroud)

无论在javascrypt中获得的组合,我似乎无法弄清楚什么是政策和什么签名,是的!我已经阅读了API,但不清楚这2个输入中的内容.我已经尝试将PolicyJson64和sig的值放在策略输入上.我也尝试过签名输入sig和pemKey的值.

我收到此错误:

<Error>
<Code>SignatureDoesNotMatch</Code>
<Message>
The request signature we calculated does not match the signature you provided. Check your Google secret key and signing method.
</Message>
<StringToSign>
a/vDHoeJ1jIZibjgLnS/ZfMftmyz8IaISJiVt1b2wDNbDjnSR+0HyEDW9/Lew7ufMjU9xdtX/Uld06IJbeYz3OWGHnH4osJNS614RoDVd7lq2qft+bSCqYPtkagJiUWs9SNOPvuQzISthqloPQOwJ1LLXHYmV52c73OpexAnSR4=
</StringToSign>
</Error>
Run Code Online (Sandbox Code Playgroud)

我该怎么办?

------ UPDATE ------

请不要复制无效的粘贴文档.赏金补充

che*_*o_c -4

由于 Google Cloud Storage 没有简单的方法来上传图像(2014 年),我最终使用了 Amazon Web Services,它甚至附带了 NodeJS 示例代码。使用方便且简单。

http://aws.amazon.com/es/developers/getting-started/nodejs/

克隆样本:

git clone https://github.com/awslabs/aws-nodejs-sample.git
Run Code Online (Sandbox Code Playgroud)

安装:

npm install
Run Code Online (Sandbox Code Playgroud)

跑步:

node sample.js
Run Code Online (Sandbox Code Playgroud)

该示例附带了存储桶的使用情况,他们甚至在存储桶中存储了一个文件。这样就可以了。确保更改您的凭据:

aws_access_key_id = YOUR_ACCESS_KEY_ID
aws_secret_access_key = YOUR_SECRET_ACCESS_KEY
Run Code Online (Sandbox Code Playgroud)

干杯!