This code will help you upload Base64 images with attachment_fu gem without any extra gem.
#Sample base64 code. You can use your own.
code = ""
REGEXP = /\Adata:([-\w]+\/[-\w\+\.]+)?;base64,(.*)/m
new_code = code.match(REGEXP) || []
new_code = new_code[2] if new_code[2].present?
#Following patch will convert base64 code to a file and upload it using Carrierwave gem. You can loop this patch as well and you can pass dynamic original_filename and content_type attributes.
StringIO.open(Base64.decode64(new_code)) do |data|
data.class.class_eval { attr_accessor :original_filename, :content_type }
data.original_filename = "TEST.png"
data.content_type = "image/png"
Profile.last.receipts.create({:uploaded_data => data})
end
In above code, I am calling my Profile.last.receipt_images.create({:uploaded_data => data})
. Simple!
Here, receipt_images
is the child object of Profile
.
Note: uploaded_data
is the default attribute of attachment_fu gem.
REGEXP = /\Adata:([-\w]+\/[-\w\+\.]+)?;base64,(.*)/m
user = User.find_by_id(params[:user_id])
params[:receipt_codes].each_with_index do |code,index|
new_code = code.match(REGEXP) || []
new_code = new_code[2] if new_code[2].present?
StringIO.open(Base64.decode64(new_code)) do |data|
data.class.class_eval { attr_accessor :original_filename, :content_type }
data.original_filename = params[:file_names][index]
data.content_type = params[:file_types][index]
user.receipts.create({uploaded_data: data})
end
end
end