我正在处理一个SQLCE数据库,其中一个表有一个image
类型列,用于存储XPS文档的原始二进制数据。
我正在将此数据读入byte[]
,然后将其保存到磁盘,如下所示:
File.WriteAllBytes(myPath, myByteArray);
这很有效。我可以双击myPath
处的文件并在Microsoft XPS Viewer中查看它。如果我将其重命名为ZIP文件,那么我可以在WinZip中打开它。
但是当我尝试将完全相同的文件加载到我的WPF应用程序中的DocumentViewer中时,如下所示:
var xpsDocument = new XpsDocument(myPath, FileAccess.Read);
var sequence = xpsDocument.GetFixedDocumentSequence();
// ...
第一行失败,出现以下异常:
File contains corrupted data.
A System.IO.FileFormatException occurred
at MS.Internal.IO.Zip.ZipIOEndOfCentralDirectoryBlock.FindPosition(Stream archiveStream)
at MS.Internal.IO.Zip.ZipIOEndOfCentralDirectoryBlock.SeekableLoad(ZipIOBlockManager blockManager)
at MS.Internal.IO.Zip.ZipArchive..ctor(Stream archiveStream, FileMode mode, FileAccess access, Boolean streaming, Boolean ownStream)
at MS.Internal.IO.Zip.ZipArchive.OpenOnFile(String path, FileMode mode, FileAccess access, FileShare share, Boolean streaming)
at System.IO.Packaging.ZipPackage..ctor(String path, FileMode mode, FileAccess access, FileShare share, Boolean streaming)
at System.IO.Packaging.Package.Open(String path, FileMode packageMode, FileAccess packageAccess, FileShare packageShare, Boolean streaming)
at System.Windows.Xps.Packaging.XpsManager..ctor(String path, FileAccess packageAccess, CompressionOption compressionOption)
at System.Windows.Xps.Packaging.XpsDocument..ctor(String path, FileAccess packageAccess, CompressionOption compressionOption)
我不明白为什么该文件将在Microsoft XPS Viewer / WinZip中打开(表明它实际上并未损坏),而不是通过我的代码。
令人沮丧的是,它并不一致。对于数据库中的某些值,它可以工作,而对于其他值则不然。 (虽然一致的哪些值会失败,哪些不会失败)。
以前有人遇到过这个问题,或者知道原因/解决方法吗?
答案 0 :(得分:0)
您可能需要将字节作为流读取并使用xps打包。这个解决方案对我有用:
var webClient = new System.Net.WebClient();
var data = webClient.DownloadData(myPath);
var package = System.IO.Packaging.Package.Open(new System.IO.MemoryStream(data));
var xpsDocument = new System.Windows.Xps.Packaging.XpsDocument(package,
System.IO.Packaging.CompressionOption.SuperFast,
myPath);
var sequence = xpsDocument.GetFixedDocumentSequence();