凤凰elixir二进制数据图像

时间:2016-02-13 23:46:00

标签: image elixir phoenix-framework bytea

我使用凤凰框架创建网页并创建上传表单,以便用户可以上传个人资料图片。

    def update(conn, %{"id" => id, "user" => %{"photo" => file}}) do
     if(File.exists?(file.path)) do

     case File.read(file.path) do
      {:ok, body}      -> data = IO.iodata_to_binary(body)
                          changeset = Whiteboard.File.changeset(%Whiteboard.File{}, %{user_id: currentuser.id, name: file.filename , data: data})

这样工作和二进制数据在数据库中就像bytea / binary。

现在我的问题:如何在phoenix html.eex文件中渲染二进制数据以再次显示图像?

编辑:找到一个解决方案

def render("image.html", %{:height => height, :width => width, :data =>   data, :datatype => datatype}) do
  pic = Base.encode64(data)

Phoenix.HTML.raw("<img src=\"data:image/"<>datatype<>";base64,"<>pic<>"\" height=\""<>height<>"\" width=\""<>width<>"\">")

end

1 个答案:

答案 0 :(得分:2)

虽然浏览器支持添加base64图像URL,但我建议您采用传统方法,即缓存可以更轻松地使用,并创建一个新的Phoenix路径来提供图像。

要做到这一点,您只需要发出正确的mime类型标题,而不是渲染模板,只需将列的内容直接放入连接中即可。

您应该检查前几个字节,看它是否与已知格式的白名单相匹配。您可以在这里搜索这些字节:http://www.garykessler.net/library/file_sigs.html