Image与byte[]数组的相互转换



    最近项目有个需求是关于图片操作的,需要将图片保存到数据库中,经过尝试才知道Image类型文件是不能直接存储到数据库中的。保存之前需要我们做一步转换:将Image转换成字节数组类型Byte[]。转换需要用到读写内存的MemoryStream类:

    MemoryStream类用于向内存而不是磁盘读写数据。MemoryStream封装以无符号字节数组形式存储的数据,该数组在创建MemoryStream对象时被初始化,或者该数组可创建为空数组。可在内存中直接访问这些封装的数据。内存流可降低应用程序中对临时缓冲区和临时文件的需要。

    Image转Byte[]方法:

        public byte[] imageToByteArray(System.Drawing.Image imageIn)
        {
            MemoryStream ms = new MemoryStream();
            imageIn.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);//将此图像以指定的格式保存到指定的流中
            return ms.ToArray();   //将流内容写入字节数组
        }

    转换完成后,存入Oracle数据库时还会报错:

                             

     这是因为在Oracle中BLOB类型的字段用于存储二进制数据,而非Byte[]。所以仍需要进一步转换。

             Bytep[]转换为Blob类型:

 OracleParameter[] para = new OracleParameter[2];    //类似SQLParameter,shape为参数               
                 para[0] = new OracleParameter("shape", OracleType.Blob, picBo.BPicBig.Length);
                 para[0].Value = picBo.BPicBig;      //picBo.BPicBig为byte[]类型
                 para[1] = new OracleParameter("shape1", OracleType.Blob, picBo.BPicSmall.Length);
                 para[1].Value = picBo.BPicSmall;


    转换完成后即可将图片保存至数据库。

    如果界面需要展示数据库中的图片时,就需要进行Byte[]到Image的转换了:

public Image byteArrayToImage(byte[] byteArrayIn)
{
     MemoryStream ms = new MemoryStream(byteArrayIn);
     Image returnImage = Image.FromStream(ms);
     return returnImage;
}



  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 40
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 40
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值