PrintSystemDesiredAccess Enumeration

Definition

Gibt die verschiedenen Zugriffsrechte (oder Zugriffsebenen) für das Drucken von Objekten an.

public enum class PrintSystemDesiredAccess
public enum PrintSystemDesiredAccess
type PrintSystemDesiredAccess = 
Public Enum PrintSystemDesiredAccess
Vererbung
PrintSystemDesiredAccess

Felder

Name Wert Beschreibung
None 0

Kein Zugriff.

EnumerateServer 131074

Die Rechte zum Auflisten der Warteschlangen auf dem Druckserver.

UsePrinter 131080

Das Recht zum Hinzufügen von Druckaufträgen zur Warteschlange und zum Löschen und Aufzählen der eigenen Aufträge.

AdministrateServer 983041

Das Recht, alle administrativen Aufgaben für den Druckserver auszuführen. Diese Zugriffsebene enthält AdministratePrinterkeine Rechte für die vom Server gehosteten Druckwarteschlangen.

AdministratePrinter 983052

Das Recht, alle administrativen Aufgaben für die Druckwarteschlange auszuführen, einschließlich des Rechts zum Anhalten und Fortsetzen eines Druckauftrags; und das Recht, alle Aufträge aus der Warteschlange zu löschen. Diese Zugriffsebene umfasst auch alle Rechte unter UsePrinter.

Beispiele

Das folgende Beispiel zeigt, wie Sie diese Enumeration verwenden, um einen zweiten Drucker zu installieren, der sich in seinen Eigenschaften von einem vorhandenen Drucker nur an Position, Port und freigegebenem Status unterscheidet.

LocalPrintServer myLocalPrintServer = new LocalPrintServer(PrintSystemDesiredAccess.AdministrateServer);
PrintQueue sourcePrintQueue = myLocalPrintServer.DefaultPrintQueue;
PrintPropertyDictionary myPrintProperties = sourcePrintQueue.PropertiesCollection;

// Share the new printer using Remove/Add methods
PrintBooleanProperty shared = new PrintBooleanProperty("IsShared", true);
myPrintProperties.Remove("IsShared");
myPrintProperties.Add("IsShared", shared);

// Give the new printer its share name using SetProperty method
PrintStringProperty theShareName = new PrintStringProperty("ShareName", "\"Son of " + sourcePrintQueue.Name +"\"");
myPrintProperties.SetProperty("ShareName", theShareName);

// Specify the physical location of the new printer using Remove/Add methods
PrintStringProperty theLocation = new PrintStringProperty("Location", "the supply room");
myPrintProperties.Remove("Location");
myPrintProperties.Add("Location", theLocation);

// Specify the port for the new printer
String[] port = new String[] { "COM1:" };

// Install the new printer on the local print server
PrintQueue clonedPrinter = myLocalPrintServer.InstallPrintQueue("My clone of " + sourcePrintQueue.Name, "Xerox WCP 35 PS", port, "WinPrint", myPrintProperties);
myLocalPrintServer.Commit();

// Report outcome
Console.WriteLine("{0} in {1} has been installed and shared as {2}", clonedPrinter.Name, clonedPrinter.Location, clonedPrinter.ShareName);
Console.WriteLine("Press Return to continue ...");
Console.ReadLine();
Dim myLocalPrintServer As New LocalPrintServer(PrintSystemDesiredAccess.AdministrateServer)
Dim sourcePrintQueue As PrintQueue = myLocalPrintServer.DefaultPrintQueue
Dim myPrintProperties As PrintPropertyDictionary = sourcePrintQueue.PropertiesCollection

' Share the new printer using Remove/Add methods
Dim [shared] As New PrintBooleanProperty("IsShared", True)
myPrintProperties.Remove("IsShared")
myPrintProperties.Add("IsShared", [shared])

' Give the new printer its share name using SetProperty method
Dim theShareName As New PrintStringProperty("ShareName", """Son of " & sourcePrintQueue.Name & """")
myPrintProperties.SetProperty("ShareName", theShareName)

' Specify the physical location of the new printer using Remove/Add methods
Dim theLocation As New PrintStringProperty("Location", "the supply room")
myPrintProperties.Remove("Location")
myPrintProperties.Add("Location", theLocation)

' Specify the port for the new printer
Dim port() As String = { "COM1:" }


' Install the new printer on the local print server
Dim clonedPrinter As PrintQueue = myLocalPrintServer.InstallPrintQueue("My clone of " & sourcePrintQueue.Name, "Xerox WCP 35 PS", port, "WinPrint", myPrintProperties)
myLocalPrintServer.Commit()

' Report outcome
Console.WriteLine("{0} in {1} has been installed and shared as {2}", clonedPrinter.Name, clonedPrinter.Location, clonedPrinter.ShareName)
Console.WriteLine("Press Return to continue ...")
Console.ReadLine()

Hinweise

Die Zugriffsrechte, die auf jeder Zugriffsebene verfügbar sind, variieren je nach Den folgenden:

  • Ob der Druckserver ein Computer oder eine Druckserver-Appliance ist.

  • Das verwendete Betriebssystem.

  • Die installierten Sicherheitsupdates.

  • Die unterstützten Sicherheitsrichtlinien.

Aus diesem Grund sind Zugriffsrechtbeschreibungen im Abschnitt "Mitglieder" typisch für die Rechte, die jeder Zugriffsebene entsprechen, aber die aufgeführten Zugriffsebenen können mehr oder weniger Rechte auf bestimmten Systemen bieten.

Diese Werte werden in erster Linie als Parameter für PrintServer und PrintQueue Konstruktoren verwendet. Die Konstruktoren lösen Ausnahmen aus, wenn Sie einen Wert verwenden, der nur auf eine andere Art von Objekt angewendet werden kann. Übergeben Sie beispielsweise "AdministratePrinter" nicht an einen PrintServer Konstruktor.

Gilt für: