将指定图片转成二进制数组,以及将二进制数组保存到数据库中的方法
2015-10-30 12:12
1026 查看
在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();
}
这样就可以,这个叫啥方法的我也给忘记了,我只记得这个方法好像可以避免注入式漏洞攻击的,取出的方法就是平常的方法,只要转成二进制数组的格式就可以直接使用了!
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();
}
这样就可以,这个叫啥方法的我也给忘记了,我只记得这个方法好像可以避免注入式漏洞攻击的,取出的方法就是平常的方法,只要转成二进制数组的格式就可以直接使用了!
相关文章推荐
- Android之获取手机上的图片和视频缩略图thumbnails
- 数据库链接字符串查询网站
- c#调用COM组件
- DB2实例管理
- DB2实例管理
- 保障MySQL数据安全的14个最佳方法
- mysql问答汇集
- 创建一个空的IBM DB2 ECO数据库的方法
- 按右键另存图片只能存BMP
- photoshop去除图片上的水印
- Access 2000 数据库 80 万记录通用快速分页类
- 开通一个数据库失败的原因的和解决办法
- 一个简单的asp数据库操作类
- C#实现把指定数据写入串口
- CentOS下DB2数据库安装过程详解
- C#动态创建button的方法
- C#中抽象方法与虚拟方法的区别
- c#中虚函数的相关使用方法
- C#使用加边法计算行列式的值