如果我试图解释为什么我需要做我想做的事情需要很长时间,但基本上是这样的:我有FileUpload控件供用户选择一个Jpeg文件,我做了上传,之后我想将该文件转换为字节并将其用作Image控件的源代码。BinaryReader.ReadBytes转换为字符串时返回垃圾
我的代码是这一个:
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
,它可以解决问题。
UPDATE 至于问,这是从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
变量保存到数据库中。
希望这澄清了我的问题
解释的图像字节数组的字符串是不会给你任何可理解的东西。看看你的图像如何存储在MySql中将会很有趣。有可能在保存或检索中进行一些转换。 –
已更新它以显示我如何保存到MySql。 –