如何解决GetFontData在ASP.NET App中返回-1GDI_ERROR,但在控制台应用程序中未返回是什么原因造成的?
| 我们在其中一个Web应用程序中使用PDFSharp(GDI +构建)。在一个PDF导出器中,我们使用的是非系统truetype字体,它在开发环境中的工作方式像超级按钮,但是在生产环境中运行时会崩溃。 开发人员和生产人员之间的主要区别(我认为)是,生产服务器在Windows Server 2008 64位上运行,而开发服务器在2008 32位上运行。我写了一个很小的测试程序来调试。try
{
new XFont(\"ocrb10\",10,XFontStyle.Regular,new XPdfFontOptions(PdfFontEncoding.Unicode,PdfFontEmbedding.Always));
}
catch (Exception exc) { Console.WriteLine(exc.StackTrace); }
错误消息是InvalidOperationException:内部错误。无法检索字体数据。
at PdfSharp.Fonts.OpenType.FontData.CreateGdiFontImage(XFont font,XPdfFontOptions options)
at PdfSharp.Fonts.OpenType.FontData..ctor(XFont font,XPdfFontOptions options)
at PdfSharp.Fonts.OpenType.OpenTypeDescriptor..ctor(XFont font,XPdfFontOptions options)
at PdfSharp.Fonts.OpenType.OpenTypeDescriptor..ctor(XFont font)
at PdfSharp.Fonts.FontDescriptorStock.CreateDescriptor(XFont font)
at PdfSharp.Drawing.XFont.get_Metrics()
at PdfSharp.Drawing.XFont.Initialize()
at PdfSharp.Drawing.XFont..ctor(String familyName,Double emSize,XFontStyle style,XPdfFontOptions pdfOptions)
我从源代码构建了PDFSharp,并添加了一些调试代码以了解发生了什么。问题是对GetFontData的pinvoke调用返回-1(GDI_ERROR)。 PdfSharp作者在FontData.cs中添加了有关此问题的注释,在该注释中发生了错误(搜索GDI_ERROR),但他也没有找到合适的解决方案。
// Line 138 in FontData.cs,this GetFontData returns -1 here when
// running as a web application on a 64bit windows host (regardles of WOW64
// being enabled or not)
int size = NativeMethods.GetFontData(hdc,null,0);
现在,对我来说,问题是当我将代码作为控制台应用程序运行时,无法在任何环境中重现此错误。我尝试过为应用程序池打开和关闭WOW64,并且尝试过使用我自己的凭据运行应用程序池,以防出现任何与权限相关的问题,但无济于事。
WWW的PDFSharp构建很好地工作了,很可能如果我们找不到任何解决方案,我们将直接切换到该解决方案,但是我真的很想知道是什么原因引起的。
谁能帮我进一步的调试步骤吗?在IIS / ASP.NET中运行时,与PInvokes控制台应用程序相比,环境在哪些方面有所不同?
解决方法
根据MSDN,对于开发人员来说,依靠GDI +检索字体指标非常普遍。
GDI +函数和类不是
支持在Windows中使用
服务。尝试使用这些
Windows中的函数和类
服务可能会产生意外
问题,例如服务减少
性能和运行时异常或
错误。
在FontData.cs中,我发现了以下内容:
#if GDI
100 /// <summary>
101 /// Create the font image using GDI+ functionality.
102 /// </summary>
103 void CreateGdiFontImage(XFont font,XPdfFontOptions options/*,XPrivateFontCollection privateFontCollection*/)
104 {
105 System.Drawing.Font gdiFont = font.RealizeGdiFont();
106 NativeMethods.LOGFONT logFont;
...
这就是为什么WPF构建确实按您在问题中所述的那样工作时,PDFSharp的GDI +构建无法在服务中运行的原因。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。