ASP.NET使用WPS WORD转PDF
开发环境:
Windows10 64位+ WPS 2019企业版 +Visual Studio 2019
这是最近又接触到了word和excel转pdf的问题,所以跑回来更新了一下这文。个人感觉在.NET里还是
wps比较友好一些。虽然可能大家都在用npoi,我自己还是喜欢wps。
开发步骤 :
1.直接官网下载wps企业版,安装好后自己网上找个激活码就行,一定得激活或者你有破解版也行,不然还是调用不起来
2.代码引用微软的office组件就行,wps的本质其实也是基于office。
下面直接上代码(代码我是直接从另一个大佬的论坛搬过来的,添加了一些我自己的理解):
// An highlighted block
public class WordToPdfHelper : IDisposable{public static readonly log4net.ILog log =log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);dynamic wps;public WordToPdfHelper(){//创建wps实例,需提前安装wpsType type = Type.GetTypeFromProgID("KWps.Application");//如果CreateInstance()报错出现检索 COM 类工厂中 CLSID 为{} 的组件时失败,有几种情况 我在下面会解释wps = Activator.CreateInstance(type);}/// <summary>/// Word转PDF/// </summary>/// <param name="wordPath">Word文件路径</param>/// <param name="pdfPath">Pdf文件路径</param>/// <returns></returns>public bool ToPdf(string wordPath, string pdfPath=null){try{if (wordPath == null){throw new ArgumentNullException("wpsFilename");}if (pdfPath == null){pdfPath = Path.ChangeExtension(wordPath, "pdf");}//用wps 打开word不显示界面dynamic doc = wps.Documents.Open(wordPath, Visible: false);//doc 转pdf doc.ExportAsFixedFormat(pdfPath, Microsoft.Office.Interop.Word.WdExportFormat.wdExportFormatPDF);//设置隐藏菜单栏和工具栏//wps.setViewerPreferences(PdfWriter.HideMenubar | PdfWriter.HideToolbar);doc.Close();Dispose(); //用完了记得释放进程}catch (Exception ex){Dispose(); return false;}return true;}public void Dispose(){if (wps != null) { wps.Quit(); }}}
**代码很简单,过程我就只遇到下面这问题,如果有朋友有疑问也可以留言,我看到会帮你解答
Type type = Type.GetTypeFromProgID(“KWps.Application”);
这句如果没有安装WPS是取不到type 的会出现NULL。
Activator.CreateInstance(type);
这里花费了我最多时间。第一次遇到COM引用出错:
检索 COM 类工厂中 CLSID 为 {000209FF-0000-4B30-A977-D214852036FF} 的组件失败,原因是出现以下错误: 80070005 拒绝访问。 (异常来自 HRESULT:0x80070005 (E_ACCESSDENIED))。
遇到这个错误需要把IIS的线程池里的应用程序池标识改为LocalSystem
这样就可以顺利运行啦