2011-10-10 24 views
8

Używam biblioteki EPPlus 2.8.0.2 w mojej aplikacji ASP.NET MVC 3 do generowania plików Excel. Ta aplikacja działa w IIS 6 w systemie Windows Server 2003 R2.Inicjalizacja nie powiodła się w IsolatedStorage

Linia wykraczająca to:

xlsdoc.GetAsByteArray 

xlsdoc jest prawidłowo załadowany Przedmiotem ExcelPackage.

Generowanie małą moc jest w porządku, ale generuje dużą moc generuje błąd:

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 

Podejrzewam EPPlus próbuje utworzyć pliki tymczasowe za pomocą IsolatedStorage, ale nie masz uprawnień do zapisu IsolatedStorage. Zmieniłem tożsamość puli aplikacji na "system lokalny", a błąd zniknął.

Jak uniknąć tego błędu podczas korzystania z tożsamości "usługa sieciowa"?

+0

Powiązany problem i więcej informacji dla każdego, kto znalazł to: http://epplus.codeplex.com/workitem/14762 – richardtallent

Odpowiedz

8

Ktoś blogged about this. Błąd dostał (odmowa dostępu) różnił się od błędu, który dostałem, ale jego rozwiązanie pracował dla mnie:

  • Utwórz folder na serwerze w C:\Documents and Settings\Default User\Local Settings\Application Data\IsolatedStorage
  • Nadanie uprawnień do zapisu każdego do tego folderu
+1

link dead on 2014-08-05 – JerryOL

0

Omówiono tutaj: http://openxmldeveloper.org/

ekstrakt:

create folder named IsolatedStorage at the following path "C:\Documents and Settings\Default User\Local Settings\Application Data" and give the permission for IIS_WPG to modify and write. This solves the problem on the windows server 2003

Powiązane problemy