java - 谷歌应用程序引擎java错误使用blobstore api从云存储检索文件

标签 java google-app-engine google-cloud-storage blobstore

在使用云存储客户端 API 时,我开始遇到 30MB 文件大小限制。经过研究,我发现 GAE 文档建议我使用 BlobStore API。

我创建了一个初始测试来上传到我的云服务中的存储桶。我注意到的一件事是文件名丢失了,而是使用了 key 。没什么大不了的,我现在保留了 blob 键和我想要存储的文件元数据之间的映射。

然后,我尝试使用 blobstoreService.createGsBlobKey() 方法下载该文件。我正在传递以下内容: “/gs/”+bucketName+“/”+fBlob.getBlobKey()),其中 fBlob 是我的映射对象,其中包含文件信息和 blob 键。

** 编辑 ** 我还尝试使用文件的实际名称而不是 blob 键(我不太确定文档要求什么),但结果是相同的。

方法 getBlobKey() 就是这样做的。它返回我从 BlobKey.getKeyString() 方法检索到的字符串。

一切看起来都很顺利,直到我访问传递参数来检索文件的 servlet。我所有的日志转储看起来都不错。更令人沮丧的是日志中没有任何错误。存在问题的唯一迹象是通用网页显示发生了 500 错误,如果我继续遇到此错误,则在支持论坛中发布消息。

所以我在这里:)

任何帮助将不胜感激。我会提供更多信息(即堆栈跟踪),但正如我提到的,没有任何信息。以下是 servlet 的摘要:

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws     ServletException, IOException {
    String iopsKey = request.getParameter("iopsId");
    String itemId = request.getParameter("itemId");
    String digitalId = request.getParameter("resourceId");

    Logger.getAnonymousLogger().info("Site Id: " + iopsKey);
    Logger.getAnonymousLogger().info("Item Id: " + itemId);
    Logger.getAnonymousLogger().info("Digital Good Id: " + digitalId);

    final DigitalResource resource = delegate.getDigitalResource(iopsKey, itemId, digitalId);
    Logger.getAnonymousLogger().info("Contents of Digital Resource: " + resource);

    FileBlobMap fBlob = delegate.findBLOBByFilename(resource.getInternalName());
    Logger.getAnonymousLogger().info("Contents of FileBlogMap: " + fBlob);

    BlobstoreService blobstoreService = BlobstoreServiceFactory.getBlobstoreService();
    BlobKey blobKey = blobstoreService.createGsBlobKey("/gs/vendor-imports/" + fBlob.getBlobKey());

    blobstoreService.serve(blobKey, response);
}

编辑 #2 ** 经过一番尝试后,我意识到 blobstore API 生成的 key /名称似乎与云存储中实际存储的内容并不相关。

使用 blobstore api 时,我只知道有 2 个字段可用于映射回存储的文件:来自 blob 键对象的键字符串和文件的实际名称。但是,在云存储中创建的名称/键值是另一个键字符串,据我所知似乎与任何内容都不匹配。

现在,如果我从云存储复制 key /名称并将其硬编码到通过数据存储查看器存储文件名/blobkey 映射的对象,那么一切都会正常!因此,云存储中的引用与我在回调处理程序中获得的内容之间似乎存在脱节。

已解决 ** 有一个附加方法是我正在使用的 FileInfo 对象的一部分,但我没有注意到。此方法称为 getGsObjectName(),它返回一个完全映射的字符串,其中包含“/gs/”前缀以及我在云存储中看到的 token 字符串。这对我来说并不是很明显,所以希望这篇文章将来能节省其他人的时间。

最佳答案

我认为您在创建 blobKey 时可能遇到问题。您的 fBlob.getBlobKey() 已经返回 blobKey 但您尝试将其放入另一个 blobKey 中。您是否尝试将该 key 传递给 blobstoreService.serve 方法:

blobstoreService.serve(fBlob.getBlobKey(), response);

您看到的通用页面也是出现服务器错误时由 AppEngine 提供的错误页面。您应该检查控制台是否有任何异常。如果您在生产环境中运行,您可以检查 AppEngine 控制台中的日志以查看错误的详细信息。

关于java - 谷歌应用程序引擎java错误使用blobstore api从云存储检索文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20873949/

相关文章:

google-cloud-storage - ML-Engine 无法访问存储桶中的 job_dir 目录

python - 将文件从 Google Compute Engine VM 上运行的 docker 镜像复制到 Google Storage 存储桶

java - Google 的 AppEngine - java.nio.BufferOverflowException

python - 在这个 python 代码中产生 "TypeError character mapping must return integer..."是什么?

google-cloud-platform - 区域 europe-west1 去了哪里?

python - GCM python 服务器端实现 : Error=MissingRegistration

java - 为什么我的 java 编译器级别与我安装的项目方面不匹配?

java - 如何在Lucene 6.2.0的CustomAnalayzer中使用SynonymMap

java - 带有单选按钮的 JFrame 布局

java - 稍后调用时 fragment View 属性为 null