Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/393.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/80.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 如何将html5画布图像保存到mssql varbinary(max)字段?_Javascript_Sql_Asp.net_Vb.net_Html - Fatal编程技术网

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

Javascript 如何将html5画布图像保存到mssql varbinary(max)字段?,javascript,sql,asp.net,vb.net,html,Javascript,Sql,Asp.net,Vb.net,Html,JAVASCRIPT-将画布图像保存到DATAURL 此代码在单击时将base64字符串绑定到hiddenfield save.addEventListener('click', function (event) { var dataUrl = canvas.toDataURL(); $('txtbx').val(dataUrl); }); VB.NET-将BASE64字符串提交到SQL 此代码在单击时将base64字符串提交到数据库(如VarChar) 问题: 如何: 将画布图像

JAVASCRIPT-将画布图像保存到DATAURL

此代码在单击时将base64字符串绑定到hiddenfield

save.addEventListener('click', function (event) {
  var dataUrl = canvas.toDataURL();
  $('txtbx').val(dataUrl);
});
VB.NET-将BASE64字符串提交到SQL

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


问题: 如何:

  • 将画布图像另存为varbinary字符串?
  • 将base64字符串转换为varbinary?
欢迎任何将图像字符串获取到varbinary字段的替代解决方案

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


简单解决方案

答案很简单,将字符串包装如下:

Convert.FromBase64String(base64Decode)

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

我在表格中做了这个快速测试,效果很好:

        //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););
您不需要任何字符数组或流,只需删除URI中无用的部分(
substring
piece),并将其转换为字节数组(
convert…


ADO.NET将自动将字节数组转换为MSSQL所需的varbinary。

也许您需要先将表列[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
试试看,让我们知道它是否有效

编辑:


看起来您确实需要对数据进行解码。我已更新了程序。请查看有关编码/解码的详细信息。

您可以发布存储过程的代码吗?您只需更新存储过程并将base64字符串强制转换为varbinary即可…根据Microsoft文档尝试此操作,但收到错误消息,字符串为太长,无法转换。有什么想法吗?在尝试转换之前,您是否删除了所有“无用”部分?数据URI格式为
Data:[];charset=][;base64],
(来自Wikipedia),您应该发送给函数的唯一部分是
收到的错误:指定的路径、文件名或两者都太长。完全限定的文件名必须少于260个字符,目录名必须少于248个字符。“您的代码有问题,base64字符串被解释为路径??非常感谢您的帮助。我知道我非常接近。我添加了用于转换的函数。字符串似乎正确,但出现了上述错误。这会将base64字符串转换为二进制字符串吗?”?
@image VARCHAR(MAX)
AS
BEGIN
    SET NOCOUNT ON;

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

END