FoxIt PDF SDK - PrintWithDialog 中的 AccessViolationException
FoxIt PDF SDK - AccessViolationException in PrintWithDialog
场景:WinForms 桌面应用,.Net 2.0
我们有 0.01% 的用户无法打印我们通过 FoxIt PDF SDK ActiveX v5.0.1 呈现的文档
当用户单击 "Print" 按钮时,我们会在查看器控件实例上调用 PrintWithDialog() 方法。此时抛出Access Violation Exception,然后应用程序挂起。打印对话框未显示。没有进一步的用户输入(鼠标、键盘)使其恢复生机,必须通过任务管理器终止该进程。
异常堆栈跟踪是:
AccessViolationException - Attempted to read or write protected memory. This is
often an indication that other memory is corrupt.
at System.RuntimeType.ForwardCallToInvokeMember(String memberName, BindingFlags flags, Object target, Int32[] aWrapperTypes, MessageData& msgData)
at FoxitPDFSDKStdLib._DFoxitPDFSDK.PrintWithDialog()
at AxFoxitPDFSDKStdLib.AxFoxitPDFSDK.PrintWithDialog()
at MyCode.PDFToolBarButtonClick(Object sender, EventArgs e)
我们无法重现问题,而且 FoxIt 似乎也无能为力,因为我们无法给他们提供重现问题的项目。
我怀疑 Windows 7 和打印设置的组策略控制。我们已经成功地要求受影响的用户删除并重新安装默认打印机,但是一两天后问题又出现了。一个站点具有控制谁可以进行彩色打印的策略设置,并以不同方式安装打印机(同一台物理设备)。
有没有人有过 Windows 7 或组策略设置影响打印的经验?
编辑:只有 FoxIt 受此问题影响。其他一切 - Acrobat、Word、Notepad 等都可以正常打印。
我可以模拟这种情况,如果我删除默认打印机设置(意味着没有打印机设置为默认值),所以暂时将以下 window 注册表项从 "Device" 重命名为 "OldDevice"
HKEY_CURRENT_USER\Software\Microsoft\Windows NT\CurrentVersion\Windows\Device
我的简单表格:
public Form1()
{
InitializeComponent();
try
{
this.axFoxitPDFSDK1.OpenFile(@"C:\foxit\FoxitPDFActiveX51_Manual.pdf", "");
this.axFoxitPDFSDK1.PrintWithDialog();
}
catch (System.Exception exc)
{
Debug.WriteLine(exc.StackTrace);
Debug.WriteLine(exc.Message);
if (exc.InnerException != null)
{
Debug.WriteLine(exc.InnerException.Message);
}
}
}
以及调试的相关输出:
Eccezione first-chance di tipo 'System.AccessViolationException' in mscorlib.dll
'MySOfoxit.vshost.exe' (Gestito (v2.0.50727)): 'C:\Windows\assembly\GAC_MSIL\System.Configuration.0.0.0__b03f5f7f11d50a3a\System.Configuration.dll' caricato, caricamento simboli ignorato. Il modulo è ottimizzato e l'opzione 'Just My Code' del debugger è abilitata.
in System.RuntimeType.ForwardCallToInvokeMember(String memberName, BindingFlags flags, Object target, Int32[] aWrapperTypes, MessageData& msgData)
in FoxitPDFSDKStdLib._DFoxitPDFSDK.PrintWithDialog()
in AxFoxitPDFSDKStdLib.AxFoxitPDFSDK.PrintWithDialog()
in MySOfoxit.Form1..ctor() in c:\foxit\MySOfoxit\Form1.cs:riga 23
Tentativo di lettura o scrittura della memoria protetta. Spesso questa condizione indica che altre parti della memoria sono danneggiate.
我可以提到这个 link 作为(可能)触发事件的可能原因之一。其他应用程序(WinWord、Adobe Reader)按预期工作(只需要手动选择打印机)
场景:WinForms 桌面应用,.Net 2.0
我们有 0.01% 的用户无法打印我们通过 FoxIt PDF SDK ActiveX v5.0.1 呈现的文档
当用户单击 "Print" 按钮时,我们会在查看器控件实例上调用 PrintWithDialog() 方法。此时抛出Access Violation Exception,然后应用程序挂起。打印对话框未显示。没有进一步的用户输入(鼠标、键盘)使其恢复生机,必须通过任务管理器终止该进程。
异常堆栈跟踪是:
AccessViolationException - Attempted to read or write protected memory. This is
often an indication that other memory is corrupt.
at System.RuntimeType.ForwardCallToInvokeMember(String memberName, BindingFlags flags, Object target, Int32[] aWrapperTypes, MessageData& msgData)
at FoxitPDFSDKStdLib._DFoxitPDFSDK.PrintWithDialog()
at AxFoxitPDFSDKStdLib.AxFoxitPDFSDK.PrintWithDialog()
at MyCode.PDFToolBarButtonClick(Object sender, EventArgs e)
我们无法重现问题,而且 FoxIt 似乎也无能为力,因为我们无法给他们提供重现问题的项目。
我怀疑 Windows 7 和打印设置的组策略控制。我们已经成功地要求受影响的用户删除并重新安装默认打印机,但是一两天后问题又出现了。一个站点具有控制谁可以进行彩色打印的策略设置,并以不同方式安装打印机(同一台物理设备)。
有没有人有过 Windows 7 或组策略设置影响打印的经验?
编辑:只有 FoxIt 受此问题影响。其他一切 - Acrobat、Word、Notepad 等都可以正常打印。
我可以模拟这种情况,如果我删除默认打印机设置(意味着没有打印机设置为默认值),所以暂时将以下 window 注册表项从 "Device" 重命名为 "OldDevice"
HKEY_CURRENT_USER\Software\Microsoft\Windows NT\CurrentVersion\Windows\Device
我的简单表格:
public Form1()
{
InitializeComponent();
try
{
this.axFoxitPDFSDK1.OpenFile(@"C:\foxit\FoxitPDFActiveX51_Manual.pdf", "");
this.axFoxitPDFSDK1.PrintWithDialog();
}
catch (System.Exception exc)
{
Debug.WriteLine(exc.StackTrace);
Debug.WriteLine(exc.Message);
if (exc.InnerException != null)
{
Debug.WriteLine(exc.InnerException.Message);
}
}
}
以及调试的相关输出:
Eccezione first-chance di tipo 'System.AccessViolationException' in mscorlib.dll
'MySOfoxit.vshost.exe' (Gestito (v2.0.50727)): 'C:\Windows\assembly\GAC_MSIL\System.Configuration.0.0.0__b03f5f7f11d50a3a\System.Configuration.dll' caricato, caricamento simboli ignorato. Il modulo è ottimizzato e l'opzione 'Just My Code' del debugger è abilitata.
in System.RuntimeType.ForwardCallToInvokeMember(String memberName, BindingFlags flags, Object target, Int32[] aWrapperTypes, MessageData& msgData)
in FoxitPDFSDKStdLib._DFoxitPDFSDK.PrintWithDialog()
in AxFoxitPDFSDKStdLib.AxFoxitPDFSDK.PrintWithDialog()
in MySOfoxit.Form1..ctor() in c:\foxit\MySOfoxit\Form1.cs:riga 23
Tentativo di lettura o scrittura della memoria protetta. Spesso questa condizione indica che altre parti della memoria sono danneggiate.
我可以提到这个 link 作为(可能)触发事件的可能原因之一。其他应用程序(WinWord、Adobe Reader)按预期工作(只需要手动选择打印机)