将指定图片转成二进制数组,以及将二进制数组保存到数据库中的方法

      在winform中点击选择显示图片功能,我这边是用的pictureBox控件,现在pictureBox控件中的双击事件中用以下方法,这边是使用OpenFileDialog类打开选择得到图片的路径并且显示

        string str = "";
        private void pictureBox1_DoubleClick(object sender, EventArgs e)
        {
            OpenFileDialog openfile = new OpenFileDialog();
            if (openfile.ShowDialog() == DialogResult.OK && (openfile.FileName != ""))
            {
                str = openfile.FileName;
                pictureBox1.Image = reph(Getbyte(str));
            }
        }


这时候的str保存的是所选图片的路径,这里的reph(Getbyte(str))用到了两个办法,一个是将图片转换成二进制数组,一个是将二进制数组转换成image类型,方法如下

        /// <summary>
        /// 将指定图片转换成二进制数组
        /// </summary>
        /// <param name="value"></param>
        /// <returns></returns>
        public byte[] Getbyte(string value)
        {
            FileStream fs = new FileStream(value, FileMode.Open);
            byte[] bydata = new byte[fs.Length];
            fs.Read(bydata, 0, bydata.Length);
            fs.Close();
            return bydata;
        }
        /// <summary>
        /// 将二进制数组转换成image类型
        /// </summary>
        /// <param name="streambyte"></param>
        /// <returns></returns>
        public Image reph(byte[] streambyte)
        {
            MemoryStream ms = new MemoryStream(streambyte);
            Image img = Image.FromStream(ms);
            return img;
        }


目前就可以将图片转换成二进制数组,也可以转换成image类型,之前有朋友建议转换成string 类型,我试了一下,强烈建议不要转成string类型,转换之后的字符串很长很长,很占空间。

         将二进制数组保存到数据库中也挺麻烦的,特别是像我这种菜鸟,保存的办法如下

 FileStream fs = new FileStream(str, FileMode.Open, FileAccess.Read);
            BinaryReader br = new BinaryReader(fs);
            byte[] imabytesin = br.ReadBytes((int)fs.Length);
            using (SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["DB"].ConnectionString))
            {
                conn.Open();
                SqlCommand cmd = new SqlCommand();
                cmd.Connection = conn;
                cmd.CommandText = "insert into ShuYang_Get (Get_image,Get_Name) values (@Get_image,'" + "20" + "')";
                SqlParameter par = new SqlParameter("@Get_image", SqlDbType.Image);
                par.Value = imabytesin;
                cmd.Parameters.Add(par);
                int t = (int)(cmd.ExecuteNonQuery());
                if (t > 0)
                {
                    MessageBox.Show("OK");
                }
                else
                {
                    MessageBox.Show("NO");
                }
                conn.Close();
            }


这样就可以,这个叫啥方法的我也给忘记了,我只记得这个方法好像可以避免注入式漏洞攻击的,取出的方法就是平常的方法,只要转成二进制数组的格式就可以直接使用了!

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值