繁体   English   中英

使用blobstore api从云存储中检索文件的Google App引擎Java错误

[英]google app engine java error using blobstore api to retrieve file from cloud storage

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

我创建了一个初始测试以上传到我的云服务中的存储桶。 我注意到的一件事是文件名丢失了,而是使用了一个密钥。 没关系,我现在坚持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生成的键/名称似乎与云存储中实际存储的不相关。

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

现在,如果我从云存储中复制密钥/名称并将其硬编码到通过DataStore Viewer存储文件名/ blobkey映射的对象,则一切正常! 因此,似乎在云存储中的引用与我在回叫处理程序中获得的内容之间存在脱节。

已解决**我正在使用的FileInfo对象中还有一个我没有注意到的附加方法。 此方法称为getGsObjectName(),它返回一个完全映射的字符串,该字符串包含“ / gs /”前缀以及我在云存储中看到的令牌字符串。 这对我来说不是立即显而易见的,因此希望这篇文章可以节省其他人的时间。

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

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

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

已解决**我正在使用的FileInfo对象中还有一个我没有注意到的附加方法。 此方法称为getGsObjectName(),它返回一个完全映射的字符串,该字符串包含“ / gs /”前缀以及我在云存储中看到的令牌字符串。 这对我来说不是立即显而易见的,因此希望这篇文章可以节省其他人的时间。

很抱歉,如果我的格式已关闭,并且我在多个地方都拥有“解决方案”,那么对不起。 这是我第一次发布,因此我有点领先。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM