如果我试图解释为什么我需要做我想做的事情,那将需要很长时间,但基本上是这样的:我有 FileUpload 控件供用户选择 Jpeg 文件,我进行上传,然后我想要将该文件转换为字节并将其用作 Image 控件的源。
我的代码是这个:
string fileName = Server.MapPath("~/TempImages") + @"\foto.jpg";
fileUpload1.SaveAs(fileName);
System.IO.FileStream fs = new System.IO.FileStream(fileName, System.IO.FileMode.Open, System.IO.FileAccess.Read);
System.IO.BinaryReader binaryReader = new System.IO.BinaryReader(fs);
long byteLength = new System.IO.FileInfo(fileName).Length;
byte[] buffer = binaryReader.ReadBytes((Int32)byteLength);
fs.Close();
fs.Dispose();
string valor = System.Text.Encoding.UTF8.GetString(buffer);
img.ImageUrl = "data:image/jpg;base64," + valor;
字节数组看起来不错,但是当我将它转换为字符串时,它充满了无法识别的字符,我有另一个页面,我在其中做同样的事情,但我没有从文件中获取字节,而是从 MySql 数据库中获取它并使用相同的System.Text.Encoding.UTF8.GetString
它可以毫无问题地工作。
更新 如要求,这是我从 MySql 数据库中检索时使用的代码:
DataView dv = (DataView)SqlDataSource3.Select(DataSourceSelectArguments.Empty);
byte[] buffer = (byte[])dv.Table.Rows[0]["BIN_FOTO"];
string valor = System.Text.Encoding.UTF8.GetString(buffer);
img.ImageUrl = "data:image/jpg;base64," + valor;
这个 SqlDataSource3 的选择很简单Select BIN_FOTO from temp_image
。我从网络摄像头捕获 WPF 程序将此值存储在数据库中,用于转换网络摄像头捕获的图像的代码是:
private string ImageToBase64String(System.Drawing.Image imageData, ImageFormat format)
{
string base64;
MemoryStream memory = new MemoryStream();
imageData.Save(memory, format);
base64 = System.Convert.ToBase64String(memory.ToArray());
memory.Close();
memory.Dispose();
return base64;
}
然后我将base64
变量保存到数据库中。
希望这能澄清我的问题