我试图抓取一个即将到来的gzip文件,其中将包含照片,我想提取这个gzip,并为每一张照片上传到s3。上传不是我的问题,我不确定如何正确解析传入的gzip和获取照片。
这就是我到目前为止在我的控制器里所拥有的。
raw_gzip_file = request.raw_post
photos = Zlib::GzipReader.open(gzip_file)
photos.each{|photo| s3.upload(photo)}然而,im接收错误范围从(没有隐式StringIO转换为字符串)和(字符串包含空字节)。
如有任何帮助或建议,将不胜感激。
发布于 2015-05-09 11:52:07
您可以使用需要文件名的GzipReader方法或期望包含数据的IO的new方法创建new。
raw_post返回一个字符串,因此您要将实际的原始数据传递给一个需要文件名的方法。您可以将它包装在StringIO中,然后使用open,但是request上已经有一个方法可以这样做(如果还没有读取底层输入,则返回它)。
reader = Zlib::GzipReader.new(request.body)只有当主体确实包含gzip数据时,这才是正确的。例如,如果请求是由提交带有文件输入的表单的浏览器发出的,那么文件数据将在params中,就像普通的表单输入一样(原始的post数据将包含GzipReader无法处理的多部分mime消息)
完成了所有这些工作后,您会发现Ruby的gzip库不支持单个存档中的多个文件(请参阅问题)。如果你能让人们上传压缩文件(可能对消费者更友好),那么rubyzip创业板就可以处理这些文件。
https://stackoverflow.com/questions/30133240
复制相似问题