Winform下如何上传图片并显示出来。同时保存到数据库

通常,我们在开发软件或者网站是否,通常有时候需要添加图片,我们怎么做呢,直接贴例子。

前提是添加openFileDialog控件哈

#region 定义公共的类对象及变量
        SqlConnection sqlcon;       //声明数据库连接对象
        SqlDataAdapter sqlda;        //声明数据桥接器对象
        DataSet myds;                     //声明数据集对象
        //定义数据库连接字符串
        //string strCon = @"Data Source=lll;Database=db_CSharp;uid=sa;pwd=;";
        string strCon = "Data Source=ASUS-PC;Initial Catalog=BookManager;Integrated Security=True";
        #endregion

private void AddPhoto_Load(object sender, EventArgs e) //初始化
        {
            ShowInfo();//显示用户信息
        }

【1】选择图片按钮

private void button1_Click(object sender, EventArgs e)//选择图片
        {
            //定义可选择的头像类型
            openFileDialog1.Filter = "*.jpg,*jpeg,*.bmp,*.ico,*.png,*.tif,*.wmf|*.jpg;*jpeg;*.bmp;*.ico;*.png;*.tif;*.wmf";
            openFileDialog1.Title = "选择用户头像";
            //判断是否选择了头像
            if (openFileDialog1.ShowDialog() == DialogResult.OK)
            {
                //显示选择的用户头像
                pictureBox1.Image = Image.FromFile(openFileDialog1.FileName);
                textBox1.Text = "";
            }
        }

【2】保存图片按钮

private void button2_Click(object sender, EventArgs e)
        {
            if (textBox1.Text.Trim() == "")
            {
                MessageBox.Show("用户名不为空","信息提示");
            }
            if (openFileDialog1.FileName == "")
            {
                MessageBox.Show("用户头像不为空", "信息提示");
            }

sqlcon = new SqlConnection(strCon);//创建链接对象
            sqlcon.Open();//打开数据库
            string sqlstr = "select * from userphoto where name=‘"+textBox1.Text.Trim()+"‘";
            SqlCommand Mycom = new SqlCommand(sqlstr,sqlcon);
            Mycom.ExecuteNonQuery();
            if (null != Mycom.ExecuteScalar())
            {
                MessageBox.Show("用户名 "+textBox1.Text.Trim() + " 已经存在,请重新注册用户名", "信息提示");
                textBox1.Text = "";
                textBox1.Focus();
            }
            //sqlcon.Close();//关闭数据库
            /***************************************************************/
           else if (openFileDialog1.FileName != "" && textBox1.Text != "")//如果用户名不为空,并且文件被选中
            {
                //添加用户信息
                if (AddInfo(textBox1.Text, openFileDialog1.FileName))
                {
                    MessageBox.Show("用户信息添加成功", "信息提示");
                }
               
            }
            //else
            //{ 
            //    MessageBox.Show("请您输入用户名", "信息提示"); 
            //}
            sqlcon.Close();//关闭数据库
            ShowInfo();
        }

【3】调用的函数:

#region 添加用户信息
        /// <summary>
        /// 添加用户信息
        /// </summary>
        /// <param name="strName">用户名称</param>
        /// <param name="strImage">选择的头像名称</param>
        /// <returns>执行成功,返回true</returns>
        private bool AddInfo(string strName, string strImage)
        {
            sqlcon = new SqlConnection(strCon);//创建数据库连接对象

FileStream FStream = new FileStream(//创建文件流对象
                strImage, FileMode.Open, FileAccess.Read);
            BinaryReader BReader = new BinaryReader(FStream);//创建二进制流对象
            byte[] byteImage = BReader.ReadBytes((int)FStream.Length);//得到字节数组

SqlCommand sqlcmd = new SqlCommand(//创建命令对象
                "insert into userphoto(name,photo) values(@name,@photo)", sqlcon);

sqlcmd.Parameters.Add("@name", //添加参数并赋值
                SqlDbType.VarChar, 50).Value = strName;
            sqlcmd.Parameters.Add("@photo",//添加参数并赋值
                SqlDbType.Image).Value = byteImage;

sqlcon.Open();//打开数据库连接
            sqlcmd.ExecuteNonQuery();//执行SQL语句
            sqlcon.Close();//关闭数据库连接
            return true;//方法返回布尔值
        }
        #endregion

*******************************************************************

#region 在DataGridView中显示用户名称
        /// <summary>
        /// 在DataGridView中显示用户名称
        /// </summary>
        private void ShowInfo()//显示到DataGridView表格
        {
            sqlcon = new SqlConnection(strCon);//创建链接对象
            sqlda = new SqlDataAdapter("select name as 用户名称 from userphoto", sqlcon);//查询SQL
            myds = new DataSet();//填充数据集
            sqlda.Fill(myds);
            dataGridView1.DataSource = myds.Tables[0];//显示
        }
        #endregion

********************************************************

#region 显示用户信息
        /// <summary>
        /// 显示用户头像
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            //记录选择的用户名
            string strName = dataGridView1.Rows[e.RowIndex].Cells[0].Value.ToString().Trim();
            if (strName != "")
            {
                sqlcon = new SqlConnection(strCon);     //实例化数据库连接对象
                //实例化数据桥接器对象
                sqlda = new SqlDataAdapter("select * from userphoto where name=‘" + strName + "‘", sqlcon);
                myds = new DataSet();                   //实例化数据集对象
                sqlda.Fill(myds);                       //填充数据集
                //显示用户名称
                textBox1.Text = myds.Tables[0].Rows[0][1].ToString();
                //使用数据库中存储的二进制头像实例化内存数据流
                MemoryStream MStream = new MemoryStream((byte[])myds.Tables[0].Rows[0][2]);
                pictureBox1.Image = Image.FromStream(MStream);  //显示用户头像
            }
        }
        #endregion

文章出处:https://blog.csdn.net/paullink520/article/details/19563881

原文地址:https://www.cnblogs.com/net-sky/p/9338951.html

时间: 2024-08-30 15:18:49

Winform下如何上传图片并显示出来。同时保存到数据库的相关文章

C#(WinForm)上传图片保存到数据库和从数据库读取图片显示到窗体

1 //浏览图片 2 3 private void btnUp_Click(object sender, EventArgs e) 4 5 { 6 7 OpenFileDialog ofd = new OpenFileDialog(); 8 9 ofd.Title = "选择要上传的图片"; 10 11 ofd.Filter = "All Files(*.*)|*.*|位图(*.bmp)|*.bmp|JPEG(*.jpg)|*.jpg"; 12 13 ofd.Sho

winform下通过webclient使用非流方式上传(post)数据和文件

这两天因为工作的需要,需要做一个winform上传数据到服务器端的程序.当时第一个想法是通过webservice的方式来实现,后来觉得麻 烦,想偷懒就没有用这样的方式,http的post方式变成了第一选择.因为以前用的都是httpwebrequest之类的东西进行post提 交,winform下面还真的是第一次,不过很快就在网上找到了webclient这个类,接下来开始实现功能,话说webclient用起来还真的很简 单,一个头信息的声明,然后是URL,最后是post的数据,就完事了.正在高兴的

php实现上传图片保存到数据库的方法

http://www.jb51.net/article/61034.htm 作者:傲雪星枫 字体:[增加 减小] 类型:转载 这篇文章主要介绍了php实现上传图片保存到数据库的方法,可通过将图片保存在数据库实现多台服务器共享文件的功能,非常具有实用价值,需要的朋友可以参考下 php实现上传图片保存到数据库的方法.分享给大家供大家参考.具体分析如下: php 上传图片,一般都使用move_uploaded_file方法保存在服务器上.但如果一个网站有多台服务器,就需要把图片发布到所有的服务器上才能

一个Winform下DataGridView控件外观的自定义类

一.关于起因 最近非常频繁的使用DataGridView控件,VS提供的Winform下DataGridView的默认样式非常难看.如果做美化处理的话,需要调整的地方非常多,且该控件的很多设置属性非常的晦涩,不是很人性化.每次进行设置都煞费脑筋,并且需要设置的DataGridView控件又比较多,如果手工一个一个调整非常麻烦.如果在每个窗体里逐个一行一行的用代码来设置,会造成代码很凌乱.琐碎,因此我对DataGridView格式设置的常用项封装到一个Helper类,通过这个帮助类可以一步到位完成

分享在winform下实现模块化插件编程

其实很早之前我就已经了解了在winform下实现插件编程,原理很简单,主要实现思路就是:先定一个插件接口作为插件样式及功能的约定,然后具体的插件就去实现这个插件接口,最后宿主(应用程序本身)就利用反射动态获取实现了插件接口的类型作为合法的插件,从而完成动态加载及宿主与插件之间的互动.因为之前一段时间一直搞B/S架构开发没有时间去实践,而恰好现在公司领导要求我对我公司原有的ERP系统架构进行重整,我们的ERP系统采用的基于分布式的三层架构,核心业务逻辑放在服务端,展示层与业务层之间采用基于WEB服

winform下 PictureBox 显示网络图片

Image pic = new Image.FromStream(WebRequest.Create("http://x.com/x.jpg").GetResponse().GetResponseStream()); picturebox1.Image = pic 对读取错误的处理没有加 winform下 PictureBox 显示网络图片,布布扣,bubuko.com

(转)winform下TCP通信的简单应用

本文转载自:http://blog.csdn.net/wanlong360599336/article/details/7557064 先看效果图: TCP比较繁琐的就是三次握手定理,每次再发送数据前都要先建立连接确认. using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; us

(转)winform下UPD通信的简单应用

本文转载自:http://blog.csdn.net/wanlong360599336/article/details/7557046 先看效果图: 使用UDP的好处就是不需要三次握手,但是缺点就是存在安全隐患. QQ就是利用UDP来传输数据的. using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using Sy

winform下mapxtreme2008 v7.0 生成release版提示找不到dll问题

在winform下基于mapxtreme2008 v7.0 生成了一个地图软件,用debug方式运行无误,但改为release版时提示缺少一大堆dll,如: 无法从C:\Program Files (x86)\Common Files\MapInfo\MapXtreme\7.0.0下复制AllType.DLL 等 经搜素,在C:/Windows/assembly/GAC_32/MapInfo.CoreEngine.Wrapper/7.0.0.220__93e298a0f6b95eb1/下包含所有