在IsolatedStorage上初始化失败

时间:2011-10-10 10:15:57

标签: asp.net-mvc-3 isolatedstorage epplus

我在ASP.NET MVC 3应用程序中使用EPPlus 2.8.0.2库来生成excel文件。此应用程序在Windows Server 2003 R2上的IIS 6上运行。

违规行是:

xlsdoc.GetAsByteArray

xlsdoc是一个正确加载的ExcelPackage对象。

生成小输出很好,但生成大输出会产生错误:

System.IO.IsolatedStorage.IsolatedStorageException: Initialization failed.
   at System.IO.IsolatedStorage.IsolatedStorageFile.Init(IsolatedStorageScope scope)
   at System.IO.IsolatedStorage.IsolatedStorageFile.GetStore(IsolatedStorageScope scope, Type domainEvidenceType, Type assemblyEvidenceType)
   at MS.Internal.IO.Packaging.PackagingUtilities.ReliableIsolatedStorageFileFolder.GetCurrentStore()
   at MS.Internal.IO.Packaging.PackagingUtilities.ReliableIsolatedStorageFileFolder..ctor()
   at MS.Internal.IO.Packaging.PackagingUtilities.GetDefaultIsolatedStorageFile()
   at MS.Internal.IO.Packaging.PackagingUtilities.CreateUserScopedIsolatedStorageFileStreamWithRandomName(Int32 retryCount, String& fileName)
   at MS.Internal.IO.Packaging.SparseMemoryStream.SwitchModeIfNecessary()
   at MS.Internal.IO.Packaging.SparseMemoryStream.Write(Byte[] buffer, Int32 offset, Int32 count)
   at MS.Internal.IO.Packaging.CompressEmulationStream.Write(Byte[] buffer, Int32 offset, Int32 count)
   at MS.Internal.IO.Packaging.CompressStream.Write(Byte[] buffer, Int32 offset, Int32 count)
   at MS.Internal.IO.Zip.ProgressiveCrcCalculatingStream.Write(Byte[] buffer, Int32 offset, Int32 count)
   at MS.Internal.IO.Zip.ZipIOModeEnforcingStream.Write(Byte[] buffer, Int32 offset, Int32 count)
   at System.IO.StreamWriter.Flush(Boolean flushStream, Boolean flushEncoder)
   at System.IO.StreamWriter.Write(String value)
   at System.IO.TextWriter.Write(String format, Object arg0)
   at OfficeOpenXml.ExcelWorksheet.UpdateRowCellData(StreamWriter sw)
   at OfficeOpenXml.ExcelWorksheet.SaveXml()
   at OfficeOpenXml.ExcelWorksheet.Save()
   at OfficeOpenXml.ExcelWorkbook.Save()
   at OfficeOpenXml.ExcelPackage.GetAsByteArray(Boolean save)
   at OfficeOpenXml.ExcelPackage.GetAsByteArray()
   at ReportCenterLib.ReportGenerator.GenerateStream(DataTable result, String reporttitle, String inputparmstr, String conndescs, String username, String outputtype, String templatefile) in D:\PROJECTS\reportcentermvc\sources\ReportCenterLib\ReportGenerator.vb:line 450
   at ReportCenterMVC.ReportCenterMVC.ReportController.Generate(Int64 id, IList`1 conns, IDictionary`2 parms, String outputtype) in D:\PROJECTS\reportcentermvc\sources\ReportCenterMVC\Controllers\ReportController.vb:line 218

我怀疑EPPlus尝试使用IsolatedStorage创建临时文件,但没有写入IsolatedStorage的权限。我已将应用程序池标识更改为“本地系统”,错误消失。

如何在使用“网络服务”身份时避免此错误?

2 个答案:

答案 0 :(得分:8)

有人blogged about this。他得到的错误(拒绝访问)与我得到的错误不同,但他的解决方案对我有用:

  • C:\Documents and Settings\Default User\Local Settings\Application Data\IsolatedStorage
  • 的服务器上创建一个文件夹
  • 授予该文件夹的所有人写入权限

答案 1 :(得分:0)

在这里讨论:http://openxmldeveloper.org/

提取物:

  

在以下路径“C:\ Documents and Settings \ Default User \ Local Settings \ Application Data”中创建名为IsolatedStorage的文件夹,并授予IIS_WPG修改和写入权限。这解决了Windows Server 2003上的问题