最近在做办公自动化系统的工作流部分时中有这样的要求,在每个流程的归档环节,要求将该流程的标签页面直接用二进制保存到数据库(因为我们面向的客户是公安局,出于安全性和数据备份的简便性考虑)。由于我们一般的文件上传都是一个物理上存在的文件,而这里的流程标签页面是根据ID号动态生成的,刚开始我用了一个比较笨的方法,思路是:先将这个页面保存到服务器的硬盘上,然后再上传到数据库中。方法实现如下:
HttpContext.Current.Response.AppendHeader( " Content-Disposition " , " attachment;filename=upload.doc " );HttpContext.Current.Response.Charset = "" ;HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.GetEncoding( " utf-8 " );HttpContext.Current.Response.ContentType = " application/msword " ;pn_upload.Page.EnableViewState = false ;System.IO.StringWriter tw = new System.IO.StringWriter() ;System.Web.UI.HtmlTextWriter hw = new System.Web.UI.HtmlTextWriter(tw);pn_upload.RenderControl(hw);HttpContext.Current.Response.Write(tw.ToString());HttpContext.Current.Response.End();
这样页面就以Word格式保存到计算机上了,然后执行上传到数据库的操作,这样也能实现客户的需求,但给人的感觉总是怪怪的,肯定是个下下策了。
今天无意之中在网上看到了一篇文章,原文来自:,可以很好的解决这个问题。
首先需要引用 System.Net 这个命名空间,然后操作如下:
HttpWebRequest hwq = (HttpWebRequest)WebRequest.Create( " http://localhost/pwtest/webform1.aspx " );HttpWebResponse hwr = (HttpWebResponse)hwq.GetResponse(); byte [] bytes = new byte [hwr.ContentLength];Stream stream = hwr.GetResponseStream();stream.Read(bytes, 0 ,Convert.ToInt32(hwr.ContentLength)); // HttpContext.Current.Response.BinaryWrite(bytes);
HttpWebRequest 可以从Internet上读取文件,因此可以很好的解决这个问题。
以上代码在VS2003中调试通过。
可能这还不是最好的方法,希望能与各位交流。