当前位置:编程学习 > C#/ASP.NET >>

ASP.Net实现将Word转换PDF格式

答案:     前言:由于一个客户的项目中需要将WORD文档转换成PDF格式,故写了本篇实站教程
  
    需求分析:客户的项目以B/S结构为主,提供一个WORD文件在后台自动转换成PDF,经过实际测试,如果该篇WORD文档有100多页的话,转换需要20分钟左右的时间(环境:CPU是奔腾M 1.6G,512M内存),整个CPU的占用率近乎95%~100%,此结果告诉客户以后,客户提议:到客户下班后,自动转换PDF,同时如果使用人确认要查看该PDF文档,如果没有转换,提供给客户选择,是现在转换成PDF,还是由服务器在客户下班后,自动转换。
  
    项目功能:按需求分析要写两个功能
  
    第一为:B/S结构后台转换,要提交给客户选择
  
    第二为:Windows服务自动转换WORD文档到PDF
  
    这两个分类:核心的转换程序都是采用线程的方式执行,只不过第一个功能是针对一个WORD文件,第二个功能针对所有未转换的WORD文档.
  
    分析到现在:我们开始实战转换了!
  
    一:必备工具
  
    安装必须的工具MS VS.Net2003,MS Office2003,Adobe Acrobat 7.0 Professional,postscript.exe,gs811w32.exe
  
    MS VS.Net2003的安装不说明
  
    MS Office2003的安装不说明
  
    Adobe Acrobat 7.0 Professional安装说明
  
    运行setup.exe文件,出现输入序列号,就运行注册机,用鼠标在第一行刷下就可以看见序列号,复制粘贴到Adobe Acrobat 7.0 Professional安装程序对话框,安装到最后出现注册时,点击PHONE...将安装程序中显示的第二行序列号(第一行是刚才注册机生成的序列号)复制粘贴到注册机的第二行,点击右边的按钮,再用鼠标刷第三行授权号就出来了,将其复制粘贴到安装程序的最后一行,完成安装注册!
  
    postscript.exe默认安装就可以了,它是一个PDF转换时所需要的脚本
  
    gs811w32.exe默认安装就可以,它其实是个PDF虚拟打印机的驱动
  
    二:配置虚拟打印机
  
    进入Windows的控制面板,进入打印机,点击"添加打印机"图标.在安装对话框上"按一步",出现选择打印机时,在制造商一栏中选择"Generic",在打印机一栏中,选择"MS Publisher Color Printer",然后一路按下一步,知道安装结束.
  
    三:开始写第一个程序(脚本程序)
  
    为什么要使用脚本程序进行转换呢,其实实际测试过程中,使用PDF Distiller的对象引用到C#后,转换成功,但整个PDF Distiller对象不能释放,第二次再转换时,就发生了错误,故此处使用脚本程序实现转换.这样我们只要在C#的程序中调用脚本程序就可以实现WORD到PDF的转换。
  
    宿主脚本文件名:ConvertDoc2PDF.js
  
    脚本文件内容:
  
  var files = WScript.Arguments;
  var fso = new ActiveXObject("Scripting.FileSystemObject");
  var word = new ActiveXObject("Word.Application");
  var PDF = new ActiveXObject("PDFDistiller.PDFDistiller.1");
  word.ActivePrinter = "MS Publisher Color Printer";
  
  //files(0) 为WORD文档文件名
  //files(1) 为,转换后需要保存的路径
  //调用fso.GetBaseName(files(0))后,为无路径,无扩展名,的文件名
  //files.length为文件参数的个数,使用循环可以支持多个WORD文档的转换
  
  var docfile = files(0);
  var psfile = files(1) + fso.GetBaseName(files(0)) + ".ps";
  var pdffile = files(1) + fso.GetBaseName(files(0)) + ".pdf";
  var logfile = files(1) + fso.GetBaseName(files(0)) + ".log";
  
  try{
  var doc = word.Documents.Open(docfile);
  //WORD文件转成PS文件;
  word.PrintOut(false, false, 0, psfile);
  doc.Close(0);
  
  //PS文件转成PDF文件;
  PDF.FileToPDF(psfile,pdffile,"");
  
  fso.GetFile(psfile).Delete();//删除PS脚本文件
  fso.GetFile(logfile).Delete();//删除转换的日志文件
  
  word.Quit();
  WScript.Echo("isuccess");//成功
  WScript.Quit(0);
  }
  catch(x)
  {
  word.Quit();
  WScript.Echo("isfail");//失败
  WScript.Quit(0);
  }
  
    然后测试该脚本程序
  
    启动MS-DOS,输入如下命令:
  
  c:\>cscript //nologo c:\ConvertDoc2PDF.js c:\test.doc c:\
  
    说明:
  
    运行成功后将看到test.pdf文档了
  
    c:\test.doc参数对应的是脚本程序中的files(0)
  
    c:\参数对应的是脚本程序中的files(1)
  
    你可以安照该脚本改写成,支持多个参数,使用FOR循环,一次转换多个WORD文档,此处没有使用多个文件转换功能,是考虑到,该段脚本放在C#的线程中执行,这样一来也可以转换多个WORD文档.
  
    四:使用C#调用ConvertDoc2PDF.js脚本
  
    新建一个C#的WINDOWS应用程序,添加一个按钮button1
  
    添加一个函数,函数名StartConvertPDF
  
  public void StartConvertPDF()
  {
   Process proc = new Process();
   proc.StartInfo.FileName = "cmd.exe";
   proc.StartInfo.WorkingDirectory = @"c:\";
   proc.StartInfo.CreateNoWindow = true;
   proc.StartInfo.UseShellExecute = false;
   proc.StartInfo.RedirectStandardInput = true; //输入重定向
  
   proc.Start();
   proc.StandardInput.WriteLine(@"cscript //nologo c:\ConvertDoc2PDF.js c:\test.doc c:\");
   proc.StandardInput.WriteLine("exit");
   proc.WaitForExit();
  }
  
    然后在按钮的CLICK事件中添加调用线程的代码
  
  private void button1_Click(object sender, System.EventArgs e)
  {
  //定义线程序
  Thread thConvert = new Thread(new ThreadStart(StartConvertData));
  thConvert.Start();
  }
  
    注意:在测试上面的C#程序时,必须添加如下命名空间
  
  using System.Diagnostics;
  using System.Threading;
  
    五:健壮的C#调用代码(实际考虑,可放在B/S系统中)
  
    完成第4步的C#测试后,细心的读者,可能看到一点问题,那就是如何得到脚本运行后输出的结果,如何给线程中调用的StartConvertData方法传递参数
  
    1:传递参数,此话说来也可用一篇教程告诉大家线程中方法如何来传递参数,现在就讲一个方案,此种方案很多,我采用一个类,初始化这个类,然后调用该类的方法作为线程执行的方法
  
    2:得到脚本的输出结果,使用Process对象的输出重定向,就是说改变输出方向,使脚本不输出到控制台(MS-DOS窗口),而是重定向输出到C#程序中,并采用线程的异步回调方法,显示脚本运行结果。
  
    添加一个新类,类名为ToPdf
  
  using System;
  using System.Diagnostics;
  using System.ComponentModel;
  using System.Windows.Forms;
  using System.Data;
  
  namespace Doc2Pdf
  {
  public class ToPdf
  {
  private string strWord = "";//此处的WORD文件不含路径
  private string sPath = "";
  public string sExecResult = "";
  public bool bSuccess = false;
  
  public ToPdf(string sParamWord,string sParamPath)
  {
  strWord = sParamWord;
  sPath = sParamPath;
  }
  
  public void StartConvertPDF()
  {
  Process proc = new Process();
     proc.StartInfo.FileName = "cmd.exe";
&nb

上一个:ASP.NET中实时图表的实现
下一个:用ashx动态生成文件

CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,