把图片转换成二进制--把二进制转换成图片

把图片转换成二进制--把二进制转换成图片
private void button1_Click( object sender, EventArgs e)
         {
             string path = this .textBox1.Text;
             byte [] imgBytesIn = SaveImage(path);
             ShowImgByByte(imgBytesIn);
             //Parameters.Add("@Photo", SqlDbType.Binary).Value = imgBytesIn;
            
         }
         //将图片以二进制流
         public byte [] SaveImage(String path)
         {           
             FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read); //将图片以文件流的形式进行保存
             BinaryReader br = new BinaryReader(fs);
             byte [] imgBytesIn = br.ReadBytes(( int )fs.Length);  //将流读入到字节数组中
             return imgBytesIn;
         }
         //现实二进制流代表的图片
         public void ShowImgByByte( byte [] imgBytesIn)
         {
             MemoryStream ms = new MemoryStream(imgBytesIn);
             pictureBox1.Image = Image.FromStream(ms);
         }
 
二、将图片保存到数据库中,并从数据库中读取:
#region 将图片从数据库中读取
         /// <summary>
         /// 将图片从数据库中读取
         /// </summary>
         /// <param name="xs_ID">要读取图片的学号</param>
         /// <param name="ph">pictureBox1控件名</param>
         public void get_photo( string xs_ID, PictureBox ph) //将图片从数据库中读取
         {
             byte [] imagebytes = null ;
             getcon();
             SqlCommand con = new SqlCommand( "select * from S_jiben where S_num='" + xs_ID + "'" , link);
             SqlDataReader dr = con.ExecuteReader();
             while (dr.Read())
             {
                 imagebytes =( byte [])dr.GetValue(18);
             }
             dr.Close();
             con_close();
             MemoryStream ms = new MemoryStream(imagebytes);
             Bitmap bmpt = new Bitmap(ms);
             ph.Image = bmpt;
         }
         #endregion
         #region
         public void SaveImage( string MID, OpenFileDialog openF) //将图片以二进制存入数据库中
         {
             string strimg = openF.FileName.ToString();  //记录图片的所在路径
             FileStream fs = new FileStream(strimg, FileMode.Open, FileAccess.Read); //将图片以文件流的形式进行保存
             BinaryReader br = new BinaryReader(fs);
             byte [] imgBytesIn = br.ReadBytes(( int )fs.Length);  //将流读入到字节数组中
             getcon();
             StringBuilder strSql = new StringBuilder();
             strSql.Append( "update S_jiben Set xs_photo=@Photo where S_num=" + MID);
             SqlCommand cmd = new SqlCommand(strSql.ToString(), link);
             cmd.Parameters.Add( "@Photo" , SqlDbType.Binary).Value = imgBytesIn;
             cmd.ExecuteNonQuery();
             con_close();
         }
         #endregion

猜你喜欢

转载自blog.csdn.net/monk1992/article/details/82150064