当前位置:   article > 正文

将指定图片转成二进制数组,以及将二进制数组保存到数据库中的方法_按键精灵图片转字节

按键精灵图片转字节

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

  1. string str = "";
  2. private void pictureBox1_DoubleClick(object sender, EventArgs e)
  3. {
  4. OpenFileDialog openfile = new OpenFileDialog();
  5. if (openfile.ShowDialog() == DialogResult.OK && (openfile.FileName != ""))
  6. {
  7. str = openfile.FileName;
  8. pictureBox1.Image = reph(Getbyte(str));
  9. }
  10. }


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

  1. /// <summary>
  2. /// 将指定图片转换成二进制数组
  3. /// </summary>
  4. /// <param name="value"></param>
  5. /// <returns></returns>
  6. public byte[] Getbyte(string value)
  7. {
  8. FileStream fs = new FileStream(value, FileMode.Open);
  9. byte[] bydata = new byte[fs.Length];
  10. fs.Read(bydata, 0, bydata.Length);
  11. fs.Close();
  12. return bydata;
  13. }
  14. /// <summary>
  15. /// 将二进制数组转换成image类型
  16. /// </summary>
  17. /// <param name="streambyte"></param>
  18. /// <returns></returns>
  19. public Image reph(byte[] streambyte)
  20. {
  21. MemoryStream ms = new MemoryStream(streambyte);
  22. Image img = Image.FromStream(ms);
  23. return img;
  24. }


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

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

  1. FileStream fs = new FileStream(str, FileMode.Open, FileAccess.Read);
  2. BinaryReader br = new BinaryReader(fs);
  3. byte[] imabytesin = br.ReadBytes((int)fs.Length);
  4. using (SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["DB"].ConnectionString))
  5. {
  6. conn.Open();
  7. SqlCommand cmd = new SqlCommand();
  8. cmd.Connection = conn;
  9. cmd.CommandText = "insert into ShuYang_Get (Get_image,Get_Name) values (@Get_image,'" + "20" + "')";
  10. SqlParameter par = new SqlParameter("@Get_image", SqlDbType.Image);
  11. par.Value = imabytesin;
  12. cmd.Parameters.Add(par);
  13. int t = (int)(cmd.ExecuteNonQuery());
  14. if (t > 0)
  15. {
  16. MessageBox.Show("OK");
  17. }
  18. else
  19. {
  20. MessageBox.Show("NO");
  21. }
  22. conn.Close();
  23. }


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

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号