如何将html5画布图像保存到mssql varbinary(max)字段?

时间:2014-09-11 10:46:03

标签: javascript sql asp.net vb.net html5

JAVASCRIPT - 保存帆布图像到数据

此代码在点击时将base64字符串绑定到隐藏字段。

save.addEventListener('click', function (event) {
  var dataUrl = canvas.toDataURL();
  $('txtbx').val(dataUrl);
});

VB.NET - 提交BASE64字符串SQL

此代码在单击时将base64字符串提交到数据库。 (作为VarChar

Protected Sub btn_Click(ByVal sender As Object, ByVal e As EventArgs) Handles btn.Click
  Dim base64 As String = hidUrl.Value
  Dim base64Decode As String = base64.Replace("data:image/png;base64,", "")

  Dim cmd As New SqlCommand("sp", con)
  cmd.CommandType = CommandType.StoredProcedure

  Dim image As New SqlParameter("@image", SqlDbType.VarChar, -1)
  image .Direction = ParameterDirection.Input
  cmd.Parameters.Add(image).Value = base64Decode

  con.Open()
  cmd.ExecuteNonQuery()
  con.Close()
End Sub

问题

如何:

  • 将画布图像另存为varbinary字符串?
  • 将base64字符串转换为varbinary?

欢迎任何将图像字符串传递到varbinary字段的替代解决方案。

我已经阅读了很多关于此的文档但是无法实现一个工作示例。我现在需要一些专家指导。


简单解决方案

答案是简单地将字符串包装如下:

Convert.FromBase64String(base64Decode)

2 个答案:

答案 0 :(得分:1)

要将base64字符串转换为二进制数据类型,请使用Convert.FromBase64String,然后使用字节数组将其作为二进制文件存储在数据库中。

我在一个表单中做了这个快速测试,它运行良好:

        //got this datauri from http://corehtml5canvas.com/code-live/ch01/example-1.1/example.html
        var datauri = "";
        var base64 = datauri.Substring(datauri.IndexOf(',') + 1);

        var binary = Convert.FromBase64String(base64);

        pictureBox1.Image = Image.FromStream(new MemoryStream(binary));

请记住更改SP参数以使用varbinary。

您的解码功能过于复杂,您不需要,只需更改参数创建:

Dim image As New SqlParameter("@image", SqlDbType.VarBinary, -1)
  image .Direction = ParameterDirection.Input
  cmd.Parameters.Add(image ).Value = Convert.FromBase64String(base64.Substring(base64.IndexOf(',') + 1););

您不需要任何char数组或流,只需删除URI(substring段的无用部分,并将其转换为字节数组(Convert...)。

ADO.NET会自动将字节数组转换为MSSQL预期的varbinary。

答案 1 :(得分:1)

也许您需要先将表格列[Image]更新为varbinary(max)。

然后,按以下步骤更新程序:

@image VARCHAR(MAX)
AS
BEGIN
    SET NOCOUNT ON;

    UPDATE  [tbl]
    SET     [Image] = cast('' as xml).value('xs:base64Binary(sql:variable("@image"))', 'varbinary(max)')

END

尝试并告知我们是否有效。

编辑:

看起来您需要解码数据。我已经更新了proc。有关编码/解码的更多信息,请查看http://blog.falafel.com/t-sql-easy-base64-encoding-and-decoding/