我正在使用以下代码生成 pdf,它工作完美:
string strQuery = "select * from userdata";
SqlCommand cmd = new SqlCommand(strQuery);
DataTable dt = GetData(cmd);
//Create a dummy GridView
GridView GridView1 = new GridView();
GridView1.AllowPaging = false;
GridView1.DataSource = dt;
GridView1.DataBind();
Response.ContentType = "application/pdf";
Response.AddHeader("content-disposition", "attachment;filename=GridViewExport.pdf");
Response.Cache.SetCacheability(HttpCacheability.NoCache);
StringWriter sw = new StringWriter();
HtmlTextWriter hw = new HtmlTextWriter(sw);
GridView1.RenderControl(hw);
StringReader sr = new StringReader(sw.ToString());
Document pdfDoc = new Document(PageSize.A4, 10f, 10f, 10f, 0f);
HTMLWorker htmlparser = new HTMLWorker(pdfDoc);
PdfWriter.GetInstance(pdfDoc, Response.OutputStream);
pdfDoc.Open();
htmlparser.Parse(sr);
pdfDoc.Close();
Response.Write(pdfDoc);
Response.End();
效果很好。但我可以将此 pdf 保存到服务器地图路径上。
我在 pdfDoc.Close(); 之后写了下面的内容
String path = Server.MapPath("~/mypdf.pdf");
但它没有将 pdf 保存到服务器地图路径。
我怎样才能做到这一点?
您当前正在将文档写入以下输出流:Response.OutputStream
一旦你这样做了pdfDoc.Close();
,PDF 字节消失了。
如果要将 PDF 保存到服务器,则需要替换以下行:
PdfWriter.GetInstance(pdfDoc, Response.OutputStream);
有了这一行:
PdfWriter.GetInstance(pdfDoc, new FileStream(context.Server.MapPath("~") + "mypdf.pdf");
现在,您的字节不会发送到浏览器,但 PDF 将在您的服务器上创建。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)