在c#中将base64转换为Image

我正在使用MVC#。 当我尝试将base64字符串转换为图像时,图像不会被打开。 我从javascript获取base64字符串并将其转换为控制器中的图像。 这是我的代码。

var base64 = "...AgkKCA4CbBouoSAQIECBAgQIAAAQIECBAgkIaA4CaNOuoFAQIECBAgQIAAAQIECBAgkKCA4CbBouoSAQIECBAgQIAAAQIECBAgkIaA4CaNOuoFAQIECBAgQIAAAQIECBAgkKCA4CbBouoSAQIECBAgQIAAAQIECBAgkIaA4CaNOuoFAQIECBAgQIAAAQIECBAgkKCA4CbBouoSAQIECBAgQIAAAQIECBAgkIaA4CaNOuoFAQIECBAgQIAAAQIECBAgkKCA4CbBourS9wLLy8vhypUrob+/Pxw8eBALAQIECBAgQIAAAQIECBAonIDgpnAlS7vBY2Nj4e7du6GpqSkMDg4KXNIut94RIECAAAECBAgQIECAQBkBwY0hUjcC09PT4enTp9kMmdIxOzsbhoeHw/z8fOjp6QlDQ0Ohubk5XL16NbS3t4epqakwMjIS2trafvTavXv3ws2bN1e+Pjo6GmZmZkJLS8ua13R0dNSNh4YQIECAAAECBAgQIECAAAHBjTFQNwLj4+Ph2LFjq86y+XzZU29vb4ghzPHjx0NfX1/W/vj11V6LAc+FCxdCDHG6urqy82NANDk5GS5evPija+oGQ0MIECBAgAABAgQIECBAgMAnAcGNYVA3AqsFN4uLi9mSqbm5uZXlUzG4KQUypRkyMbj50ms3btzIlmCVjiNHjmTBzQ+vqRsMDSFAgAABAgQIECBAgAABAoIbY6CeBCYmJrKlUgMDAyvNiq/FmTJHjx4Nly9fDpcuXQp5gpvPZ9yUbr5a2FNPHtpCgAABAgQIECBAgAABAgTMuDEG6kqgtDlxbNTp06fD4cOHw7Vr17J9aU6dOhWWlpbCmTNnvnrGTdwDp7THTWnj49UCoLrC0BgCBAgQIECAAAECBAgQaHgBwU3DDwEABAgQIECAAAECBAgQIECAQL0KCG7qtTLaRYAAAQIECBAgQIAAAQIECDS8wP8AN7hUDozwDE4AAAAASUVORK5CYII="; byte[] str = System.Text.Encoding.Unicode.GetBytes(base64); var buffer = Convert.FromBase64String(Convert.ToBase64String(str)); var file = Server.MapPath("~/Content/images/err.png"); System.IO.File.WriteAllBytes(file, buffer); Image img = new Image(); img.ImageUrl = Server.MapPath("~/Content/images/err.png"); 

你的代码是完全错误的。

您需要通过删除第一个逗号之前的所有内容来解析该字符串中的实际base64数据。

然后,您可以对该数据调用Convert.FromBase64String()

 string source = "...YII="; string base64 = source.Substring(source.IndexOf(',') + 1); byte[] data = Convert.FromBase64String(base64); 

我复制了base64字符串提示窗口。 我使用ajax方法从客户端发布base64字符串,它适用于我

C#

 [HttpPost] public void Base64ToImage(string source) { string base64 = source.Substring(source.IndexOf(',') + 1); base64 = base64.Trim('\0'); byte[] chartData = Convert.FromBase64String(base64); } 

AJAX方法

 var picture = jqplotToImg($('#ChartContent')); //prompt("", picture); $.ajax({ type: 'POST', url: '../Report/Base64ToImage', async: false, data: { source: picture }, success: function (data) { //alert(data); } });