如何在json上存储base64图像序列化postgresql

时间:2017-06-22 08:54:04

标签: ruby-on-rails postgresql ruby-on-rails-4 ionic2 hstore

伙计们,我有一个用于保存图像的JSON序列化图像列,图像类型具有base64编码(更多细节:在离子2框架上我将图像转换为base64编码并发送到服务器)

产品表

t.column  :images, :string

产品型号

  mount_uploaders :images, ProductUploader
  serialize :images, JSON

现在,如何在JSON序列化列上存储base64映像? 我发现这个转换器代码用于上传操作但不能正常工作

def parse_image_data(base64_image)
filename = "upload-image"
in_content_type, encoding, string = base64_image.split(/[:;,]/)[1..3]

@tempfile = Tempfile.new(filename)
@tempfile.binmode
# for example i replace an image 
@tempfile.write ""
@tempfile.rewind

# for security we want the actual content type, not just what was passed in
content_type = `file --mime -b #{@tempfile.path}`.split(";")[0]

# we will also add the extension ourselves based on the above
# if it's not gif/jpeg/png, it will fail the validation in the upload model
extension = content_type.match(/gif|jpeg|png/).to_s
filename += ".#{extension}" if extension

ActionDispatch::Http::UploadedFile.new({
  tempfile: @tempfile,
  type: content_type,
  filename: filename
})
end




  def clean_tempfile
    if @tempfile
      @tempfile.close
      @tempfile.unlink
    end
  end

0 个答案:

没有答案