如何在asp.net中使用C#将使用jQuery flotdynamic生成的图表导出到Excel中?

我有一个使用jQuery flot工具生成图表的aspx页面。 它的工作很好。 我的新要求是我必须在此页面中放置一个名为“导出到Excel”的button。 每当我点击这个button,由jQuery的flot工具生成的图表必须导出到excel文件作为图像。 它像从html页面复制和粘贴图像到excel文件。 我尝试了很多方法,但我无法得到适当的解决scheme。 帮我解决这个问题。

方法1: 1.在JavaScript中,我将图表div转换为canvas,并将asp图像控件的源代码设置为该图像。 它按预期在浏览器中显示。

var data = canvas.toDataURL('image/jpg'); document.getElementById('ctl00_ctl00_ContentPlaceHolder1_ContentPlaceHolder1_imgChart').src=data; } }); 

但是在服务器上,即使将提交button放在更新面板中,我也无法访问该图像的src。

 string picName = imgChart.ImageUrl; worksheet.Shapes.AddPicture(picName, Microsoft.Office.Core.MsoTriState.msoFalse, Microsoft.Office.Core.MsoTriState.msoCTrue, 10, 10, 100, 100); 

它显示picName是空错误。

方法2:

  1. 将图表转换为图像并存储在本地文件夹中
  2. 从Excel文件夹中添加图像文件

但问题是不能将图表转换成图像并存储在本地文件夹中。

在ASP.NET中预期这种行为。 使用JavaScript的图像更改srcpath(例如ImageUrl属性)将不会在回发中可用。

我会尝试将canvas的值也存储在HiddenField中,并从服务器端代码中取值。

JavaScript的

 var data = canvas.toDataURL('image/jpg'); document.getElementById('ctl00_ctl00_ContentPlaceHolder1_ContentPlaceHolder1_imgChart').src=data; document.getElementById('ctl00_ctl00_ContentPlaceHolder1_ContentPlaceHolder1_HiddenField1').value=data; 

C#

 string picName = HiddenField1.Value; worksheet.Shapes.AddPicture(picName, Microsoft.Office.Core.MsoTriState.msoFalse, Microsoft.Office.Core.MsoTriState.msoCTrue, 10, 10, 100, 100); 

更新 :这种方法会给你的数据:URL看起来像这样的

为了将这个string保存为C#中的图像,您需要下面的代码,我在这里find。 将该图像保存到文件系统(文件"~/temp/file.png" )之后,可以轻松地将其添加到excel中。

C#

 string data = @""; var base64Data = Regex.Match(data, @"data:image/(?<type>.+?),(?<data>.+)").Groups["data"].Value; var binData = Convert.FromBase64String(base64Data); using (var stream = new MemoryStream(binData)) { System.Drawing.Image image = new Bitmap(stream); image.Save(Server.MapPath("~/temp/file.png")); }