zoukankan      html  css  js  c++  java
  • 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;
    }
    


    
  • 相关阅读:
    Excel 2016 Power View选项卡不显示的问题
    Base64编码
    MAPI错误0x80040107
    命令行界面 (CLI)、终端 (Terminal)、Shell、TTY的区别
    C函数调用过程原理及函数栈帧分析
    SIFT(Scale-invariant feature transform) & HOG(histogram of oriented gradients)
    Jupyter NoteBook 的快捷键
    endnote插入参考文献后的对齐方式和缩进空格
    赏月斋源码共享计划 第四期 约瑟夫问题
    LRU和LFU的区别
  • 原文地址:https://www.cnblogs.com/llguanli/p/8398572.html
Copyright © 2011-2022 走看看