从ASP.NET打印到网络打印机

时间:2010-09-16 17:30:03

标签: c# .net asp.net printing system.printing

我需要将文档发送到网络打印机(\ myserver \ myprinter)。我正在使用System.Printing类进行打印,当它来自Windows服务时它可以正常工作,但是从ASP.NET应用程序中,它只能打印到本地打印机,而不能打印到网络打印机。我得到的错误是“打印机名称无效”这是我用来获取打印机名称的:

public string PrinterName
{
   using (LocalPrintServer server = new LocalPrintServer())
   return server.GetPrintQueue(@"\\myserver\myprinter");
}

我有什么选择?这是权限问题吗?

3 个答案:

答案 0 :(得分:5)

默认情况下,ASP.NET应用程序在具有有限权限的特殊帐户上运行。刚刚足以提供网页服务,仅此而已。所以你必须配置ASPNET用户。

相比之下,Windows服务通常在本地系统帐户(具有高权限)下运行

答案 1 :(得分:5)

您可以通过模拟或提升运行Web应用程序的用户的权限来解决凭据问题。

但是,我们是通过在服务器上添加网络打印机作为打印机(在服务器上添加打印机对话框)并将作业发送到该打印机来实现的。

我们使用了Printing.PrintDocument(VB中的代码)....

Public Class SpecialReportPrintJob
  Inherits Printing.PrintDocument

Protected Overrides Sub OnBeginPrint(ByVal ev as Printing.PrintEventArgs)
  MyBase.OnBeginPrint(ev)

  Me.PrinterSettings.PrinterName = "PrinterNameUsedOnServer"

  'setup rest of stuff....
End Sub  
End Class
'And we then call it like so
Dim printSpecialReport as new SpecialReportPrintJob()
printSpecialReport.Print()

答案 2 :(得分:0)

ASP.Net/C#中的网络打印可以使用以下方式完成:

如果为域用户配置了网络,则将打印机添加到打印服务器:

  • 将PrinterName定义为=“\\ PrintServerIP_OR_Name \\ PRINTERNAME” 示例:PrinterSettings.PrinterName =“\\ 15.1.1.1 \\ prn001”
  • 检查打印机访问权限
  • 上设置的权限
  • 哪个是域用户或每个人
  • 如果是Domain Users,那么C#代码可以包含在可用于调用打印代码的模拟中,如下所示:
/// <summary>
    /// Does the actual impersonation.
    /// </summary>
    /// <param name="userName">The name of the user to act as.</param>
    /// <param name="domainName">The domain name of the user to act as.</param>
    /// <param name="password">The password of the user to act as.</param>
    private void ImpersonateValidUser(
        string userName, 
        string domain, 
        string password )
    {
        WindowsIdentity tempWindowsIdentity = null;
        IntPtr token = IntPtr.Zero;
        IntPtr tokenDuplicate = IntPtr.Zero;

        try
        {
            if ( RevertToSelf() )
            {
                if ( LogonUser(
                    userName, 
                    domain, 
                    password, 
                    LOGON32_LOGON_INTERACTIVE,
                    LOGON32_PROVIDER_DEFAULT, 
                    ref token ) != 0 )
                {
                    if ( DuplicateToken( token, 2, ref tokenDuplicate ) != 0 )
                    {
                        tempWindowsIdentity = new WindowsIdentity( tokenDuplicate );
                        impersonationContext = tempWindowsIdentity.Impersonate();
                    }
                    else
                    {
                        throw new Win32Exception( Marshal.GetLastWin32Error() );
                    }
                }
                else
                {
                    throw new Win32Exception( Marshal.GetLastWin32Error() );
                }
            }
            else
            {
                throw new Win32Exception( Marshal.GetLastWin32Error() );
            }
        }
        finally
        {
            if ( token!= IntPtr.Zero )
            {
                CloseHandle( token );
            }
            if ( tokenDuplicate!=IntPtr.Zero )
            {
                CloseHandle( tokenDuplicate );
            }
        }
    }

    /// <summary>
    /// Reverts the impersonation.
    /// </summary>
    private void UndoImpersonation()
    {
        if ( impersonationContext!=null )
        {
            impersonationContext.Undo();
        }   
    }

    private WindowsImpersonationContext impersonationContext = null;

首先调用模拟用户,然后调用下面的打印函数:

if(ImpersonateValidUser("username", "domain", "password"))
{
  PrintDetails();
  UndoImpersonation();
}