我使用凤凰框架创建网页并创建上传表单,以便用户可以上传个人资料图片。
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
答案 0 :(得分:2)
虽然浏览器支持添加base64图像URL,但我建议您采用传统方法,即缓存可以更轻松地使用,并创建一个新的Phoenix路径来提供图像。
要做到这一点,您只需要发出正确的mime类型标题,而不是渲染模板,只需将列的内容直接放入连接中即可。
您应该检查前几个字节,看它是否与已知格式的白名单相匹配。您可以在这里搜索这些字节:http://www.garykessler.net/library/file_sigs.html