Question

Je suis en train de télécharger une image à PingFM. Leur dit:

media – base64 encoded media data.

Je peux accéder à cette image via l'URL. J'ai essayé (pratiquement deviné) ceci:

ActiveSupport::Base64.encode64(open("http://image.com/img.jpg"))

Mais je reçois cette erreur:

TypeError: can't convert Tempfile into String
    from /usr/lib/ruby/1.8/base64.rb:97:in `pack'
    from /usr/lib/ruby/1.8/base64.rb:97:in `encode64'
    from (irb):19
    from :0
Était-ce utile?

La solution

La méthode de open:

open("http://image.com/img.jpg")

renvoie un objet fichier temporaire, alors que encode64 attend une chaîne.

L'appel read sur le tempfile devrait faire l'affaire:

ActiveSupport::Base64.encode64(open("http://image.com/img.jpg") { |io| io.read })

Autres conseils

Pour encoder un fichier:

require 'base64'
Base64.encode64(File.open("file_path", "rb").read)

Pour produire le fichier de la chaîne codée:

require 'base64'
encoded_string = Base64.encode64(File.open("file_path", "rb").read)

File.open(file_name_to_create, "wb") do |file|
    file.write(Base64.decode64(encoded_string))
end

Cela fonctionne aussi, il est un peu plus propre

 require 'base64'

 Base64.encode64(open("file_path").to_a.join)

« Comment décodez-vous à ce retour dans un fichier? » - @ user94154

 require 'base64'

 open('output_file_name.txt', 'w') do |f| 
   f << Base64.decode64( encoded_content )
 end

encoded_content serait la valeur de retour du contenu de fichier codé précédemment.

Encode un fichier à l'encodage base64:

File.open("output_file","w"){|file| file.write [open("link_to_file").string].pack("m")}

Décodage base64 fichier codé:

File.open('original', 'wb') {|file| file << (IO.readlines('output_file').to_s.unpack('m')).first }

Voici ma solution:

1: Mettez cette méthode image_tag personnalisée dans ApplicationHelper, et comprennent le module ActiveSupport

module ApplicationHelper
  include ActiveSupport
  def image_tag_base64(file_path, mime_type = 'image/jpeg', options = {})
    image_tag("data:#{mime_type};base64,#{Base64.encode64(open(file_path) { |io| io.read })}", options)
  end
end

2: Ensuite, à l'intérieur de la vue que vous souhaitez utiliser l'image codée base64 utiliser la méthode comme ceci:

<%= image_tag_base64 @model.paperclip_attribute.path(:size), @model.paperclip_attribute.content_type, {class: 'responsive-img etc etc'} %>

3: FAIT

Dans le cas où il est utile aux autres, voici comment enregistrer une capture d'écran en base64 en utilisant Watir

browser = Watir::Browser.new(:chrome, {:chromeOptions => {:args => ['--headless', '--window-size=1000x1000']}})
browser.goto("http://www.yourimage.com")
browser.screenshot.base64

La beauté de ceci est que vous n'avez pas besoin de stocker l'image elle-même

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top