Rails:显示数据库中blob字段的图像

时间:2010-11-27 23:09:09

标签: mysql ruby-on-rails image

所以,我设法将一个图像blob放到我的MySQL数据库中(该字段中有一个大的十六进制数字),但我找不到任何关于如何在rails环境中显示图像的文档...当它打印出来,它从一个GIF89开始...然后当你在记事本中打开它时,你在GIF中看到的gobbledygook字符。 :P非常感谢任何线索!

感谢。

3 个答案:

答案 0 :(得分:22)

以下代码应该有效。在控制器中,创建一个方法:


def show_image
    @user = User.find(params[:id])
    send_data @user.image, :type => 'image/png',:disposition => 'inline'
end

在您看来:


<%= image_tag url_for(:controller => "mycontroller", :action => "show_image", :id => @user.id) %>

我建议使用Paperclip gem。它使得保存/查看图像变得非常容易。

答案 1 :(得分:12)

因为你提到“快而又脏”,我会把它作为替代 -

<%= ('<img src="data:image/jpg;base64,%s">' % Base64.encode64(@the_data)).html_safe %>

我认为这最接近你想做的事情。这个代码不应该原样使用有几个原因,但它很简单。我必须更多地思考一个想法是多么糟糕,将整个事物标记为html_safe。此外,这在旧版本的IE中不起作用。

答案 2 :(得分:5)

您还应该添加

resources :users do
     get 'show_image', :on => :collection
 end

get users/show_image" => "users#show_image"

之前

route.rb 文件

中的

resources :users