// 在ASP.NET中用数据库保存图片,对一些产品图片管理是较为方便的;
// 不过相对来说技术问题可能比用文件保存图片要复杂一些;
// (首先要声明一下,偶是半路出家的和尚,)近来在学习这个图片处理的技术时;
// 总结了一下自己的学习心得,希望有大虾给予指教;// 用SQL数据库保存图片
// SQL数据库表名:dmcimage ,字段:ImageNO int(4) (自动标识列),ImageContent Image
// 在ASPX页面上布置一个HTML控件,以获取图片;
// <input type="file" id="File1" runat="server" >
// 注意:runat="server" 不能省的;// 用后台编码文件时,首先须获得对这个HTML控件的访问:
// public System.Web.UI.HtmlControls.HtmlInputFile File1;
 
 public void Button1_Click(object sender,EventArgs e)
 {
  // 这段代码是抄了人家的,意思偶不是太懂;
  // 不过自己这样子理解的:把图片转成二进制数据,保存在变量PhotoArray里;
  
  int intFile = File1.PostedFile.ContentLength;
  byte[] PhotoArray = new byte[intFile];
  System.IO.Stream PhotoStream = File1.PostedFile.InputStream;
  PhotoStream.Read(PhotoArray,0,intFile);  
  // 此时用Response.BinaryWrite(PhotoArray)即可将图片显示在网页上呢;
  
  // 将图片数据新增到数据库中;
  // 注意cmd.Parameters.Add("@ImageContent",SqlDbType.Image)中的SqlDbType.Image属性;
  
  string sqlConnectionString;
  sqlConnectionString = "server=(local);user id=yell;password='770925';database=yelldata";
  SqlConnection conn = new SqlConnection(sqlConnectionString);
  conn.Open();
  
  string strSQL;
  strSQL = "Insert into dmcimage(ImageContent) values(@ImageContent)";
  
  SqlCommand cmd = new SqlCommand(strSQL,conn);
  cmd.Parameters.Add("@ImageContent",SqlDbType.Image);
  cmd.Parameters["@ImageContent"].Value = PhotoArray;
  
  cmd.ExecuteNonQuery();  
  conn.Close();
 }
 
 // 用ACCESS数据库时的代码;数据库的字段:ImageNO (自动编号),ImageContent(OLE 对象);
 // 注意cmd.Parameters.Add("@ImageContent",OleDbType.LongVarBinary)用的是OleDbType.LongVarBinary属性;
 
 public void Button2_Click(object sender,EventArgs e)
 {
  int intFile = File1.PostedFile.ContentLength;
  byte[] PhotoArray = new byte[intFile];
  System.IO.Stream PhotoStream = File1.PostedFile.InputStream;
  PhotoStream.Read(PhotoArray,0,intFile);
  
  string oleConnectionString;
  oleConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" 
   + "Data Source=D:\\dmcweb\\mdb\\db1.mdb;"
   + "Persist Security Info=False;" 
   + "Jet OLEDB:DataBase password='770925'";  
  OleDbConnection conn = new OleDbConnection(oleConnectionString);
  conn.Open();  string strSQL;
  strSQL = "Insert Into dmcimage(ImageContent) values(@ImageContent)";  
  
  OleDbCommand cmd = new OleDbCommand(strSQL,conn);
  cmd.Parameters.Add("@ImageContent",OleDbType.LongVarBinary);
  cmd.Parameters["@ImageContent"].Value = PhotoArray;
  
  cmd.ExecuteNonQuery();  
  conn.Close();   
 }
 
 // 备注:按道理来说,用于ACCESS数据库的代码,用OLEDB连接SQL数据库时,应该也可以的;
 // 但是上述代码在用OLEDB连接SQL数据库时,运行时出现“必须声明变量@ImageContent”的错误;
 // 至于为什么会有这种错误,我也不知道了,哪位大虾能否明示下;
 // 后来我把代码改成如下,不论是连接ACCESS或SQL数据库,都可以使用。其他数据库不会用也没有试了; 
 
 // strSQL = "Insert Into dmcimage(ImageContent) values(?)";  
 // OleDbCommand cmd = new OleDbCommand(strSQL,conn);
 // cmd.Parameters.Add("?",PhotoArray);
 
 // 呵,这个代码连那个最难找的OleDbType.LongVarBinary的属性也不用了! 
 
 // 我们在获取图片时,有时希望得到图片文件的大小,还有图片的高度和宽度;
 
 // 获取图片文件的大小
 public void Button3_Click(object sender,EventArgs e)
 {
  // 获取图片大小,单位:KB
  int intFile = File1.PostedFile.ContentLength;
  Response.Write(intFile/1024 + "<br>");
  
  // 获取图片档案的目录地址;
  // 不知道可不可以用这种方式来获取图片的格式(最后三个字符):JPG GIF BMP;
  string ImagePath = File1.PostedFile.FileName;
  Response.Write(ImagePath + "<br>");
  
  // 获取图片的高度和宽度;
  System.Drawing.Image ImageName = System.Drawing.Image.FromFile(ImagePath);  
  Response.Write(ImageName.Width + "<br>");
  Response.Write(ImageName.Height + "<br>");  
  
 }