不容易用一句话概括问题...
我有一个使用 Java 6 在 tomcat 7 上运行的 Web 应用程序。该应用程序使用使用 JNI 和 COM 的 JACOB 访问 Excel 工作表,从而启动一个单独的 Excel 进程。为了确保 Excel 工作表是可变的,我的 Java 进程使用 File.createTempFile() 创建原始 XLS 的副本并将临时文件传递给 Excel 进程。
操作系统是 Windows Server 2008。Excel 版本来自 Office 2010。
我的问题:只要从命令行或从 IDE 交互式启动 Tomcat,一切正常。如果我将 Tomcat 作为服务启动(使用默认用户 SYSTEM),Excel 将无法打开临时文件说:
com.jacob.com.ComFailException: Invoke of: Open
Source: Microsoft Excel
Description: Microsoft Excel kann auf die Datei 'C:\Program Files\apache-tomcat\temp\Entwickl-Auftr-Bez-n-Maß 54-131 215-2 Optimierung 210-0 210-3.xlsx6119727457676255726.clone' nicht zugreifen. Dies kann mehrere Gründe haben:
• Der Name des Dokuments oder der Pfad ist nicht vorhanden.
• Das Dokument wird von einem anderen Programm verwendet.
• Der Name der Arbeitsmappe, die gespeichert werden soll, ist identisch zu dem Namen eines anderen Dokuments, welches schreibgeschützt ist.
com.jacob.com.Dispatch.invokev(Native Method)
com.jacob.com.Dispatch.invokev(Unknown Source)
com.jacob.com.Dispatch.callN(Unknown Source)
com.jacob.com.Dispatch.call(Unknown Source)
de.insites.ms.com.xls.Workbook.<init>(Unknown Source)
de.insites.ms.com.xls.Excel.openWorkbook(Unknown Source)
de.harti.harticalc.excel.MahanoExcel.<init>(Unknown Source)
de.harti.harticalc.excel.MahanoExcel.create(Unknown Source)
de.harti.harticalc.excel.ExcelProcessor.getExcel(Unknown Source)
de.harti.harticalc.excel.ExcelProcessor.calculatePosition(Unknown Source)
de.harti.mahano.service.PositionServlet.doGet(Unknown Source)
javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
de.harti.mahano.service.AbstractMahanoWsServlet.service(Unknown Source)
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
de.harti.mahano.service.CharsetFilter.doFilter(Unknown Source)
德语消息意味着 Excel 无法访问该文件,因为该文件不存在、被另一个进程锁定或以某种方式被写锁定。
我验证了该文件存在并且它是一个可读的 Excel 文档(我可以使用 Excel 交互方式打开它)。
我的猜测是,Windows 拒绝 EXCEL 子进程访问我的文件,因为它是由它不信任的 java 进程创建的。
当 Tomcat 作为 Windows 服务运行时,如何让 Excel 访问该文件?
编辑:异常消息的英文版
ERROR - Invoke of: Open
Source: Microsoft Office Excel
Description: Microsoft Office Excel cannot access the file 'c:\marchena\marchena10\work\marchena\batch_58288\input\content_1.xlsx'. There are several possible reasons:
? The file name or path does not exist.
? The file is being used by another program.
? The workbook you are trying to save has the same name as a currently open workbook.
解决 方案在此处找到解决方案链接。我必须创建文件夹
C:\Windows\SysWOW64\config\systemprofile\Desktop
手动。似乎在 Windows Server 2008 上,Excel 在以 SYSTEM 身份运行时需要此文件夹,但如果缺少则不会创建。
感谢您的提示。