- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我试图通过如下设置响应 header ,让 Google App Engine 自动压缩我的 .gz blob 文件(单个压缩文件):
class download(blobstore_handlers.BlobstoreDownloadHandler):
def get(self, resource):
resource = str(urllib.unquote(resource))
blob_info = blobstore.BlobInfo.get(resource)
self.response.headers['Content-Encoding'] = str('gzip')
# self.response.headers['Content-type'] = str('application/x-gzip')
self.response.headers['Content-type'] = str(blob_info.content_type)
self.response.headers['Content-Length'] = str(blob_info.size)
cd = 'attachment; filename=%s' % (blob_info.filename)
self.response.headers['Content-Disposition'] = str(cd)
self.response.headers['Cache-Control'] = str('must-revalidate, post-check=0, pre-check=0')
self.response.headers['Pragma'] = str(' public')
self.send_blob(blob_info)
运行时,下载的文件没有 .gz 扩展名。但是,下载的文件仍然是 gzip 压缩的。下载数据的文件大小与服务器上的 .gz 文件大小匹配。另外,我可以通过手动压缩下载的文件来确认这一点。我试图避免手动 gunzip 步骤。
我试图让 blob 文件在下载过程中自动 gunzip。我做错了什么?
顺便说一下,gzip 文件只包含一个文件。在我的自托管(非谷歌)服务器上,我可以通过设置相同的响应头来完成自动 gunzip;不过,我的代码是用 PHP 编写的。
我重写了处理程序以提供存储桶中的数据。但是,这会生成 HTML 500 错误。文件在失败前已部分下载。改写如下:
class download(blobstore_handlers.BlobstoreDownloadHandler):
def get(self, resource):
resource = str(urllib.unquote(resource))
blob_info = blobstore.BlobInfo.get(resource)
file = '/gs/mydatabucket/%s' % blob_info.filename
print file
self.response.headers['Content-Encoding'] = str('gzip')
self.response.headers['Content-Type'] = str('application/x-gzip')
# self.response.headers['Content-Length'] = str(blob_info.size)
cd = 'filename=%s' % (file)
self.response.headers['Content-Disposition'] = str(cd)
self.response.headers['Cache-Control'] = str('must-revalidate, post-check=0, pre-check=0')
self.response.headers['Pragma'] = str(' public')
self.send_blob(file)
这会在服务器终止并发出 500 错误之前将 6,094,848 字节文件中的 540,672 字节下载到客户端。当我从命令行对部分下载的文件发出"file"时,Mac OS 似乎正确地将文件格式识别为“SQLite 3.x 数据库”文件。知道为什么服务器上出现 500 错误吗?我该如何解决这个问题?
最佳答案
您应该首先检查您的请求客户端是否支持 gzip 压缩内容。如果它确实支持 gzip 内容编码,那么您可以使用适当的 content-encoding
传递 gzip 压缩的 blob。和 content-type
header ,否则您需要为客户端解压缩 blob。您还应该验证您的 blob 的 content_type
不是 gzip
(这取决于您一开始是如何创建 blob 的!)
您可能还想看看 Google Cloud Storage,因为只要您在使用正确的内容编码和内容类型元数据存储数据之前正确压缩数据,它就会自动处理 gzip 传输。
请参阅此 SO 问题:Google cloud storage console Content-Encoding to gzip
或 GCS 文档:https://cloud.google.com/storage/docs/gsutil/addlhelp/WorkingWithObjectMetadata#content-encoding
您可以像在 AppEngine 中使用 blobstore 一样轻松地(如果不是更容易的话)使用 GCS,并且它似乎是 future 使用的首选存储层。我这样说是因为文件 API 已被弃用,这使得 blobstore 交互更容易,并且已经对 GCS 库做出了巨大的努力和改进,使 API 类似于基本的 python 文件交互 API
更新:
由于对象存储在 GCS 中,您可以使用 302 重定向将用户指向文件,而不是依赖 Blobstore API。这消除了 Blobstore API 和 GAE 使用您打算使用的内容类型和内容编码交付存储对象的任何未知行为。对于具有公共(public)读取 ACL 的对象,您可以简单地将它们定向到 storage.googleapis.com/<bucket>/<object>
或 <bucket>.storage.googleapis.com/<object>
.或者,如果您想让应用程序逻辑指定访问权限,您应该将对象的 ACL 保持为私有(private)并且可以使用 GCS Signed URLs创建在执行 302 重定向时使用的短期 URL。
值得注意的是,如果您希望用户能够通过GAE上传对象,您仍然需要使用Blobstore API来处理将文件存储在GCS中,但是您必须在上传到对象后修改对象确保使用正确的 gzip 压缩和内容编码元数据。
class legacy_download(blobstore_handlers.BlobstoreDownloadHandler):
def get(self, resource):
filename = str(urllib.unquote(resource))
url = 'https://storage.googleapis.com/mybucket/' + filename
self.redirect(url)
关于python - 您如何让 Google App Engine 在下载过程中进行 gunzip?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26893302/
当我尝试通过我的 .exe 文件从 url 下载 .pdf 文件时出现以下错误。 The server committed a protocol violation. Section=Response
我是一家非营利组织的 G Suite 管理员,刚刚发现数据导出功能,这似乎是个人帐户的外卖。 导出文件已准备好,现在可以从 Google Cloud Platform Storage 中的存储桶下载。
导航 引言 总体思路 七牛云相关的配置文件 获取七牛云上传token 相关类定义 核心代码实现 获取七牛云图片下载链接 公开空
这不是后端编程问题。我只能修改标记或脚本(或文档本身)。我在这里问的原因是因为我对适当术语的所有搜索都不可避免地导致有关编程此功能的问题和解决方案。我不是试图通过编程来强制它;我必须找出此 PDF 行
您好,我已在 Google AdSense 中注册,我想使用适用于 iOS 的 SDK,但目前我找不到 SDK 下载链接。 我的申请已获批准。 任何人都知道如何下载这个sdk。 我使用这个链接来描述如
我需要为当前在 SourceForge 上的 github 项目提供二进制文件和文档。在那里,我可以为我需要的下载提供一个目录结构,因为我必须为大约 10 个不同的操作系统提供几个版本。 github
我从 Canvas 下载绘图时遇到问题。这是我的代码: function downloadCanvas(link, canvasId, filename) { link.href =
ASP.NET 项目 我将使用 Azure 进行存储。问题(要求): 在我的项目中,我让注册用户下载文件。但我不希望用户将此下载链接分享给未注册的人(例如:我给注册用户的下载链接只能在他们的计算机上下
我编写了一个servlet,用于检查http header ,但我不知道为什么当页面加载时,它会自动开始下载。 /* * To change this template, choose To
我正在尝试将下载添加到我的网络浏览器,但遇到的问题是获取您尝试下载的文件的名称。这是我的下载代码: engine.locationProperty().addListener(new ChangeLi
我正在尝试下载网站的 html: String encoding = "UTF-8"; HttpContext localContext = new BasicHttpContext();
我制作了一个带有“开始下载”按钮的框架,用于从网站下载 JAR。 问题是每当我点击开始下载按钮时,整个框架就会卡住,直到下载完成,然后就正常了。 我该如何解决这个问题? 这是单击按钮时执行的代码 p
我得到这段代码来实现一些东西,它可以帮助我从给定的 URL 下载文件。 -(void)URLSession:(NSURLSession *)session downloadTask:(NSURLSes
我正在尝试创建一个 Controller 来使用流方法下载和上传文件,在我的例子中,所有文件都作为 Blob 保存在数据库中。我阅读了 Jboss Netty 的文档,但我认为这不是我的最佳解决方案。
下载并保存文件 let destination: DownloadRequest.DownloadFileDestination = { _, _ in // var fileURL = sel
使用 htaccess 我基本上试图禁止访问该页面,即 http://example.com , 但它仍然允许人们下载文件,如果他们有直接链接即 http://example.com/hi.zip .
我正在寻求将脚本与我的控制面板集成,并且由于我是新手脚本编写者而遇到问题。我想做的是用 1 个脚本下载一个文件并解压它。 示例: wget http://example.com/example.tar
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
这个问题在这里已经有了答案: Top techniques to avoid 'data scraping' from a website database (14 个答案) 关闭 5 年前。 我有
这个问题在这里已经有了答案: Reading and parsing email from Gmail using C#, C++ or Python (6 个答案) 关闭 7 年前。 我只是想,是
我是一名优秀的程序员,十分优秀!