zoukankan      html  css  js  c++  java
  • C#:将图片文件上传到数据库两种方法。

    (推荐)方法1:

    将图片复制到指定文件夹,在数据库中存储图片路径,通过读取路径来显示图片。

    string str;
            private void toolStripButton1_Click(object sender, EventArgs e)
            {
                if (openFileDialog1.ShowDialog() == DialogResult.OK)
                {
                    str = openFileDialog1.FileName;
                    pictureBox1.Image = Image.FromFile(str);
                }
            }//打开文件并在PictureBox中显示图片
    
            private void toolStripButton2_Click(object sender, EventArgs e)
            {
                string filename = DateTime.Now.Ticks.ToString();//时间戳,保证图片名称不重复
                string name = @"F:数据库作业外卖外卖外卖inDebugimage" + filename;
                File.Copy(str, name);//将图片复制到指定文件夹
                _users.Domain(name);//利用SQL将文件路径上传至数据库
            }
            private void toolStripButton3_Click(object sender, EventArgs e)
            {
                var info = _users.SelectDomain();//SQL查询路径
                pictureBox1.Image = Image.FromFile(info.Rows[0][0].ToString());//显示照片
                this.pictureBox1.Refresh();
            }

    方法2:

    将图片读成二进制后上传至数据库,再将二进制数据转化成图片。

    string str;
            private void toolStripButton1_Click(object sender, EventArgs e)
            {
                if (openFileDialog1.ShowDialog() == DialogResult.OK)
                {
                    str = openFileDialog1.FileName;
                    pictureBox1.Image = Image.FromFile(str);
                }
                
            }//打开文件并在PictureBox中显示图片
    
            private void toolStripButton2_Click(object sender, EventArgs e)
            {
                FileStream fs = new FileStream(str, FileMode.Open, FileAccess.Read);
                BinaryReader br = new BinaryReader(fs);
                byte[] imgBytesIn = br.ReadBytes(Convert.ToInt32(fs.Length));//转成二进制数据的操作
                _users.Domain(imgBytesIn);
            }
    
            private void toolStripButton3_Click(object sender, EventArgs e)
            {
                var table = _users.SelectDomain();
                byte[] imagedata = (byte[])(table.Rows[0][0]);
                MemoryStream myStream = new MemoryStream(imagedata);//转成图片
                pictureBox1.Image = Image.FromStream(myStream);//显示图片
            }
    
        }

     图片自适应picturebox用Sizemode-Stretchimage(PictureBox属性修改)。

  • 相关阅读:
    实例:如何设计一款好的Metro UI应用
    给用户和开发者最佳的.Net框架部署方案
    软件测试对嵌入式系统的影响
    如何创造出优秀的用户体验?
    Xamarin:使用C#移植Android操作系统
    WCF数据服务5.0 RTM发布
    演进式数据库建模
    zsh 命令行编辑技巧三则
    Oracle与MySQL的几点区别
    window下mysql表的修复
  • 原文地址:https://www.cnblogs.com/2HBCCC/p/6959249.html
Copyright © 2011-2022 走看看