如何设置 NETWORK SERVICE 用户Excel的信任VBA的访问
using Microsoft.Office.Core;
using Excel;
using Microsoft.Vbe.Interop;
namespace WebApplication1
{
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
Excel.ApplicationClass excelApp = new Excel.ApplicationClass();
Excel.Workbooks workBooks = excelApp.Workbooks;
Excel.Workbook workBook = workBooks.Add(true);
Excel.Sheets workSheets = workBook.Worksheets;
VBE vbe = excelApp.VBE;
}
}
}
“/111”应用程序中的服务器错误。
--------------------------------------------------------------------------------
不信任到 Visual Basic Project 的程序连接
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。
异常详细信息: System.Runtime.InteropServices.COMException: 不信任到 Visual Basic Project 的程序连接
源错误:
行 24: Excel.Workbook workBook = workBooks.Add(true);
行 25: Excel.Sheets workSheets = workBook.Worksheets;
行 26: VBE vbe = excelApp.VBE;
行 27: }
行 28: }
源文件: F:\Documents\Visual Studio 2005\Projects\WebApplication1\WebApplication1\Default.aspx.cs 行: 26
堆栈跟踪:
[COMException (0x800a03ec): 不信任到 Visual Basic Project 的程序连接
]
Excel.ApplicationClass.get_VBE() +0
WebApplication1._Default.Page_Load(Object sender, EventArgs e) in F:\Documents\Visual Studio 2005\Projects\WebApplication1\WebApplication1\Default.aspx.cs:26
System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e) +14
System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e) +35
System.Web.UI.Control.OnLoad(EventArgs e) +99
System.Web.UI.Control.LoadRecursive() +50
System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +627
--------------------------------------------------------------------------------
版本信息: Microsoft .NET Framework 版本:2.0.50727.3053; ASP.NET 版本:2.0.50727.3053
如果用WinForm执行同样的代码,则不会报错
发现Winform下, 进程中出现Excel进程,用户为 administrator
而webForm下, 进程中出现Excel进程,用户为 NETWORK SERVICE
那么如何设置 NETWORK SERVICE 用户的信任VBA的访问