微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – 从BlobKey获取Google云端存储文件

我编写了一个Google App Engine应用程序,它利用Blobstore来保存以编程方式生成的数据.为此,我使用了 Files API,遗憾的是,它已被弃用,支持Google云端存储.所以我正在重写我的助手类来使用GCS.

我希望保持接口尽可能与之前类似,也因为我在数据存储区中保留BlobKeys以保持对文件的引用(并且更改生产应用程序的模型总是很痛苦).当我将东西保存到GCS时,我检索一个BlobKey

BlobKey blobKey = blobstoreService.createGsBlobKey("/gs/" + fileName.getBucketName() + "/" + fileName.getobjectName());

按照here的规定,我坚持在数据存储区.

所以这就是问题:文档告诉我如何使用blobstoreService.serve(blobKey,resp)提供GCS文件;在servlet响应中,但是如何检索文件内容(如InputStream,字节数组或其他)以在我的代码中使用它进行进一步处理?在我当前的实现中,我使用从AppEngineFile读取的FileReadChannel(均已弃用).

解决方法

以下是将Google存储对象作为输入流打开的代码.不幸的是,您必须使用存储桶名称和对象名称而不是blob键
GcsFilename gcs_filename = new GcsFilename(bucket_name,object_name);
GcsService service = GcsServiceFactory.createGcsService();
ReadableByteChannel rbc = service.openReadChannel(gcs_filename,0);
InputStream stream = Channels.newInputStream(rbc);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


应用场景 C端用户提交工单、工单创建完成之后、会发布一条工单创建完成的消息事件(异步消息)、MQ消费者收到消息之后、会通知各处理器处理该消息、各处理器处理完后都会发布一条将该工单写入搜索引擎的消息、最终该工单出现在搜索引擎、被工单处理人检索和处理。 事故异常体现 1、异常体现 从工单的流转记录发现、
线程类,设置有一个公共资源 package cn.org.chris.concurrent; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; /** * @Descrip
Java中的数字(带有0前缀和字符串)
在Java 9中使用JLink的目的是什么?
Java Stream API Filter(过滤器)
在Java中找到正数和负数数组元素的数量
Java 9中JShell中的不同启动脚本是什么?
使用Java的位填充错误检测技术
java中string是什么
如何使用Java中的JSON-lib API将Map转换为JSON对象?