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
Winform下如何上传图片并显示出来。同时保存到数据库的更多相关文章
- C#(WinForm)上传图片保存到数据库和从数据库读取图片显示到窗体
//浏览图片 private void btnUp_Click(object sender, EventArgs e) { OpenFileDialog ofd = new OpenFileDialo ...
- C# winform 窗体应用程序之图片上传Oracle数据库保存字段BLOB
C# winform 窗体应用程序之图片上传Oracle数据库保存字段BLOB 我用的数据库是Oracle,就目前来看,许多数据库现在都倾向于Oracle数据库,对ORACLE数据库基本的操作也是必须 ...
- Winform下CefSharp的引用、配置、实例与报错排除(源码)
Winform下CefSharp的引用.配置.实例与报错排除 本文详细介绍了CefSharp在vs2013..net4.0环境下,创建Winfrom项目.引用CefSharp的方法,演示了winfro ...
- php实现上传图片保存到数据库的方法
http://www.jb51.net/article/61034.htm 作者:傲雪星枫 字体:[增加 减小] 类型:转载 这篇文章主要介绍了php实现上传图片保存到数据库的方法,可通过将图片保 ...
- C# LIstbox 解决WinForm下ListBox控件“设置DataSource属性后无法修改项集合”的问题
解决WinForm下ListBox控件“设置DataSource属性后无法修改项集合”的问题 分类: winform2008-05-24 02:33 2592人阅读 评论(11) 收藏 举报 winf ...
- 解决WinForm下ListBox控件“设置DataSource属性后无法修改项集合”
解决WinForm下ListBox控件“设置DataSource属性后无法修改项集合” 最近更新: 2013-2-15 587 很少写WinForm程序第一次使用ListBox控件就遇到了比 ...
- 分享在winform下实现模块化插件编程-优化版
上一篇<分享在winform下实现模块化插件编程>已经实现了模块化编程,但我认为不够完美,存在以下几个问题: 1.IAppContext中的CreatePlugInForm方法只能依据完整 ...
- 分享在winform下实现模块化插件编程
其实很早之前我就已经了解了在winform下实现插件编程,原理很简单,主要实现思路就是:先定一个插件接口作为插件样式及功能的约定,然后具体的插件就去实现这个插件接口,最后宿主(应用程序本身)就利用反射 ...
- 分享在winform下实现左右布局多窗口界面-续篇
之前的这篇文章<分享在winform下实现左右布局多窗口界面>已经实现了左右布局多窗口界面,今天本来是研究基于winform的插件编程,没想到顺便又找到了另一种实现方案,这种实现方案更简单 ...
随机推荐
- C语言中点操作符(.)和箭头操作符(->)
C语言中点操作符(.)和箭头操作符(->) 点说语法不太准确,许多都称该之为点运算符/操作符,箭头运算符/操作符.但是OC中叫点语法,感觉理解起来还蛮舒服.毕竟基础的C操作符中是 相同点 两个都 ...
- linux文件系统扩展属性
翻译自man手册,水平有限,有错还望不吝指出.... 扩展属性是与文件和目录相关的name:value对,用来提供文件系统的一些附加功能,例如ACL.对文件或是目录拥有读权限的用户可以看到其扩展属性. ...
- GlusterFS分布式存储系统中更换故障Brick的操作记录1
前面已经介绍了GlusterFS分布式存储集群环境部署记录,现在模拟下更换故障Brick的操作: 1)GlusterFS集群系统一共有4个节点,集群信息如下: 分别在各个节点上配置hosts.同步好系 ...
- ajax post get
1.Ajax post 方法 <%@ Page Language="C#" AutoEventWireup="true" CodeBehind=&qu ...
- [knowledge][http] http
关于,底层承载协议的规定. HTTP communication usually takes place over TCP/IP connections. The [], but other port ...
- [development][dpdk][hugepage] 大页内存的挂载
参考: [development][dpdk][hugepage] 为不同的结点分配不同大小的大页内存 完成了以上内容之后, 下一步需要做的是挂载, 大页内存只有被挂载了之后,才能被应用程序使用. 挂 ...
- hash_map
点开一道第是自己oj的第440大关,想a了,一直想却无果,学长一句点醒,开始写hash. 关于这道题呢很无语了,两天卡在这上面,而且有些dalao不到20min就a了.我太菜了. 所以要深入讨论这道题 ...
- BTree和B+Tree详解
https://www.cnblogs.com/vianzhang/p/7922426.html B+树索引是B+树在数据库中的一种实现,是最常见也是数据库中使用最为频繁的一种索引.B+树中的B代表平 ...
- java JDBC (七) org.apache.commons.dbutils 查询
package cn.sasa.demo1; import java.sql.Connection; import java.sql.SQLException; import java.util.Li ...
- es的scoll滚动查询技术
如果一次性要查出来比如10万条数据,那么性能会很差,此时一般会采取用scoll滚动查询,一批一批的查,直到所有数据都查询完处理完 使用scoll滚动搜索,可以先搜索一批数据,然后下次再搜索一批数据,以 ...