华域联盟 .Net .Net下二进制形式的文件(图片)的存储与读取详细解析

.Net下二进制形式的文件(图片)的存储与读取详细解析

.Net下图片的常见存储与读取凡是有以下几种:
存储图片:
以二进制的形式存储图片时,要把数据库中的字段设置为Image数据类型(SQL Server),存储的数据是Byte[].

1.参数是图片路径:返回Byte[]类型:

复制代码 代码如下:

public byte[] GetPictureData(string imagepath)

        {

            ////根据图片文件的路径使用文件流打开,并保存为byte[]  

            FileStream fs = new FileStream(imagepath, FileMode.Open);//可以是其他重载方法

            byte[] byData = new byte[fs.Length];

            fs.Read(byData, 0, byData.Length);

            fs.Close();

            return byData;

        }

2.参数类型是Image对象,返回Byte[]类型:

复制代码 代码如下:

public byte[] PhotoImageInsert(System.Drawing.Image imgPhoto)

        {

            //将Image转换成流数据,并保存为byte[]  

            MemoryStream mstream = new MemoryStream();

            imgPhoto.Save(mstream, System.Drawing.Imaging.ImageFormat.Bmp);

            byte[] byData = new Byte[mstream.Length];

            mstream.Position = 0;

            mstream.Read(byData, 0, byData.Length);

            mstream.Close();

            return byData;

        }

好了,这样通过上面的方法就可以把图片转换成Byte[]对象,然后就把这个对象保存到数据库中去就实现了把图片的二进制格式保存到数据库中去了。下面我就谈谈如何把数据库中的图片读取出来,实际上这是一个相反的过程。

读取图片:把相应的字段转换成Byte[]即:Byte[] bt=(Byte[])XXXX

1.参数是Byte[]类型,返回值是Image对象:

复制代码 代码如下:

public System.Drawing.Image ReturnPhoto(byte[] streamByte)

        {

            System.IO.MemoryStream ms = new System.IO.MemoryStream(streamByte);

            System.Drawing.Image img = System.Drawing.Image.FromStream(ms);

            return img;

        }

2.参数是Byte[] 类型,没有返回值,这是针对asp.net中把图片从输出到网页上(Response.BinaryWrite)

复制代码 代码如下:

public void WritePhoto(byte[] streamByte)

        {

            // Response.ContentType 的默认值为默认值为“text/html”

            Response.ContentType = "image/GIF";

            //图片输出的类型有: image/GIF  image/JPEG

            Response.BinaryWrite(streamByte);

        }

补充:
针对Response.ContentType的值,除了针对图片的类型外,还有其他的类型:

复制代码 代码如下:

Response.ContentType = "application/msword";

Response.ContentType = "application/x-shockwave-flash";

Response.ContentType = "application/vnd.ms-excel";

另外可以针对不同的格式,用不同的输出类型以适合不同的类型:

复制代码 代码如下:

switch (dataread("document_type"))

            {

                case "doc":

                    Response.ContentType = "application/msword";

                case "swf":

                    Response.ContentType = "application/x-shockwave-flash";

                case "xls":

                    Response.ContentType = "application/vnd.ms-excel";

                case "gif":

                    Response.ContentType = "image/gif";

                case "Jpg":

                    Response.ContentType = "image/jpeg";

            }

一些相关的东西,可以作为参考

复制代码 代码如下:

Image image= GetImageFromClipboard();//实现从剪切板获取图像的功能

System.IO.MemoryStream stream = new System.IO.MemoryStream();

System.Runtime.Serialization.Formatters.Binary.BinaryFormatter formatter

= new System.Runtime.Serialization.Formatters.Binary.BinaryFormatter(); formatter.Serialize(stream, image);

FileStream fs=new FileStream("xx",FileMode.Open,FileAccess.Write);
fs.Write(stream.ToArray(),0,stream.ToArray().Length);

您可能感兴趣的文章:

  • .net调用存储过程详细介绍
  • asp.net安全、实用、简单的大容量存储过程分页
  • asp.net 结合mysql存储过程进行分页代码
  • 在ASP.NET中用存储过程执行SQL语句
  • asp.net 存储过程调用
  • asp.net sql存储过程
  • ASP.NET Core Project.json文件(5)

本文由 华域联盟 原创撰写:华域联盟 » .Net下二进制形式的文件(图片)的存储与读取详细解析

转载请保留出处和原文链接:https://www.cnhackhy.com/51909.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者: sterben

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部