从Android应用中作为Google云端存储的服务帐户进行身份验证

时间:2014-11-08 19:51:14

标签: android google-oauth google-cloud-storage google-oauth-java-client

我有一个Android应用程序,最终将用户生成的内容存储在Google云端存储分区中。但我无法通过我的应用程序代码执行此操作。代码如下所示:

JsonFactory JSON_FACTORY = JacksonFactory.getDefaultInstance();
HttpTransport httpTransport = GoogleNetHttpTransport.newTrustedTransport();
KeyStore keystore = SecurityUtils.getPkcs12KeyStore();
keystore.load(resources.openRawResource(R.raw.secret), "***password***".toCharArray()); 
PrivateKey key = (PrivateKey)keystore.getKey("privatekey", "***password***".toCharArray());
credential = new GoogleCredential.Builder()
.setTransport(httpTransport)
.setJsonFactory(new JacksonFactory())
.setServiceAccountPrivateKey(key)
.setServiceAccountId("**************@developer.gserviceaccount.com")
.setServiceAccountScopes(Collections.singleton(StorageScopes.DEVSTORAGE_READ_WRITE))
.build();
credential.refreshToken();
String URI = "https://storage.googleapis.com/"+BUCKET_NAME;
HttpRequestFactory requestFactory = httpTransport.createRequestFactory(credential);
GenericUrl url = new GenericUrl(URI);
HttpRequest request = requestFactory.buildGetRequest(url);
HttpResponse response = request.execute();
String content = response.parseAsString();
Log.d("testing", "response content is: " + content);
new Storage.Builder(httpTransport, JSON_FACTORY, credential).setApplicationName("Doubts").build();

我遇到了各种各样的错误。其中之一是:

java.security.KeyStoreException: java.security.NoSuchAlgorithmException: KeyStore JKS implementation not found

官方文档只是忽略了Android应用中的用例。

1 个答案:

答案 0 :(得分:1)

我建议承担从Android客户端授权请求的责任,因为它不被视为“可信任的”客户端。

遵循的一个好习惯是生成签名的URL服务器端并将其发送给客户端,以便后者可以使用它以安全且不透明的方式将文件上载到存储桶。通过这种方式,您还可以消除客户自然私密凭证的复杂性和风险。

您可以在official docs

中找到有关已签名网址的详情