我想在访问数据库中保存图像,我使用了OLE对象。
这个想法是将图像转换为字节数组,然后在数据库中添加bytes数组。
这是功能:
public static byte[] ImageToByte(Image img)
{
ImageConverter converter = new ImageConverter();
return (byte[])converter.ConvertTo(img, typeof(byte[]));
}
这很好。
当我想将bytes数组返回给图像时,我得到一个异常:
参数异常未得到处理 参数无效。
我尝试了两个函数将bytes数组转换为图像:
public static Image ImageFromByte(byte[] image)
{
ImageConverter ic = new ImageConverter();
Image img = (Image)ic.ConvertFrom(image);//here the exception comes
return img;
}
OR:
public static Image ImageFromByte1(byte[] byteArrayIn)
{
MemoryStream ms = new MemoryStream(byteArrayIn);
Image returnImage = Image.FromStream(ms);//here the exception comes
return returnImage;
}
问题是什么,如何解决?
答案 0 :(得分:1)
尝试将图像保存到磁盘,看看是否有效。根据需要更改文件名和扩展名。
这些方面的东西:
string path = @"c:\myimage.jpg";
using (MemoryStream inputStream = new MemoryStream(byteArrayIn))
{
using (Stream file = File.Create(path))
{
byte[] buffer = new byte[8 * 1024];
int len;
while ((len = inputStream.Read(buffer, 0, buffer.Length)) > 0)
{
file.Write(buffer, 0, len);
}
}
}
编辑:将图像写入磁盘工作,我想你可以看到图像。试试这个:
using (MemoryStream inputStream = new MemoryStream(byteArrayIn))
{
using (var image = Image.FromStream(inputStream))
{
// see if this works.
// handle the image as you wish, return it, process it or something else.
}
}