Freigeben über


MsiSourceListAddSourceA-Funktion (msi.h)

Die MsiSourceListAddSource-Funktion fügt der Liste der gültigen Netzwerkquellen hinzu, die den angegebenen Quellentyp für ein Produkt oder Patch in einem bestimmten Benutzerkontext enthalten.

Die Anzahl der Quellen in der SOURCELIST Eigenschaft ist unbegrenzt.

Syntax

UINT MsiSourceListAddSourceA(
  [in] LPCSTR szProduct,
  [in] LPCSTR szUserName,
  [in] DWORD  dwReserved,
  [in] LPCSTR szSource
);

Parameter

[in] szProduct

Die ProductCode- des zu ändernden Produkts.

[in] szUserName

Der Benutzername für eine Benutzerinstallation. Unter Windows 2000 oder Windows XP sollte der Benutzername immer im Format DOMÄNE\BENUTZERNAME (oder MACHINENAME\USERNAME für einen lokalen Benutzer) enthalten sein.

Eine leere Zeichenfolge oder NULL- für eine Installation pro Computer.

[in] dwReserved

Reserviert für die zukünftige Verwendung. Dieser Wert muss auf 0 festgelegt werden.

[in] szSource

Zeigen Sie auf die Zeichenfolge, die die Quelle angibt.

Rückgabewert

Rückgabecode Beschreibung
ERROR_ACCESS_DENIED
Der Benutzer hat nicht die Möglichkeit, eine Quelle hinzuzufügen.
ERROR_BAD_CONFIGURATION
Die Konfigurationsdaten sind beschädigt.
ERROR_BAD_USERNAME
Der Benutzername konnte nicht aufgelöst werden.
ERROR_FUNCTION_FAILED
Die Funktion konnte nicht erfolgreich ausgeführt werden.
ERROR_INSTALL_SERVICE_FAILURE
Auf den Installationsprogrammdienst konnte nicht zugegriffen werden.
ERROR_INVALID_PARAMETER
An die Funktion wurde ein ungültiger Parameter übergeben.
ERROR_SUCCESS
Die Quelle wurde hinzugefügt.
ERROR_UNKNOWN_PRODUCT
Das angegebene Produkt ist unbekannt.

Bemerkungen

Ein Administrator kann installationen pro Computer, eigene nicht verwaltete Installationen pro Benutzer und die benutzerspezifischen verwalteten Installationen für jeden Benutzer ändern. Ein Nicht-Administrator kann nur installationen pro Computer und seine eigenen (verwalteten oder nicht verwalteten) Installationen pro Benutzer ändern. Benutzer können aktiviert werden, um nach Quellen zu suchen, indem Sie eine Richtlinie festlegen. Weitere Informationen finden Sie unter DisableBrowse, AllowLockdownBrowseund AlwaysInstallElevated Richtlinien.

Beachten Sie, dass diese Funktion lediglich die neue Quelle zur Liste der gültigen Quellen hinzufügt. Wenn eine andere Quelle zum Installieren des Produkts verwendet wurde, wird die neue Quelle erst verwendet, wenn die aktuelle Quelle nicht verfügbar ist.

Es liegt in der Verantwortung des Aufrufers, sicherzustellen, dass die bereitgestellte Quelle ein gültiges Quellbild für das Produkt ist.

Wenn der Benutzername eine leere Zeichenfolge oder NULL-ist, wird die Funktion auf der Installation des Produkts pro Computer ausgeführt. In diesem Fall gibt die Funktion ERROR_UNKNOWN_PRODUCT zurück, wenn das Produkt nur im Benutzerstatus installiert ist.

Wenn der Benutzername keine leere Zeichenfolge oder NULL-ist, gibt er den Namen des Benutzers an, dessen Produktinstallation geändert wird. Wenn der Benutzername der aktuelle Benutzername ist, versucht die Funktion zunächst, eine nicht verwaltete Installation des Produkts zu ändern. Wenn keine nicht verwaltete Installation des Produkts gefunden werden kann, versucht die Funktion dann, eine verwaltete Installation des Produkts pro Benutzer zu ändern. Wenn keine verwalteten oder nicht verwalteten Installationen pro Benutzer des Produkts gefunden werden können, gibt die Funktion ERROR_UNKNOWN_PRODUCT zurück, auch wenn das Produkt pro Computer installiert ist.

Diese Funktion kann keine nicht verwaltete Installation für jeden Benutzer außer dem aktuellen Benutzer ändern. Wenn der Benutzername keine leere Zeichenfolge oder NULL-ist, aber nicht der aktuelle Benutzer ist, sucht die Funktion nur nach einer verwalteten Benutzerinstallation des Produkts für den angegebenen Benutzer. Wenn das Produkt nicht pro Benutzer für den angegebenen Benutzer verwaltet wird, gibt die Funktion ERROR_UNKNOWN_PRODUCT zurück, auch wenn das Produkt pro Computer installiert ist.

Anmerkung

Der msi.h-Header definiert MsiSourceListAddSource als Alias, der die ANSI- oder Unicode-Version dieser Funktion basierend auf der Definition der UNICODE-Präprozessorkonstante automatisch auswählt. Das Mischen der Verwendung des codierungsneutralen Alias mit Code, der nicht codierungsneutral ist, kann zu Nichtübereinstimmungen führen, die zu Kompilierungs- oder Laufzeitfehlern führen. Weitere Informationen finden Sie unter Konventionen für Funktionsprototypen.

Anforderungen

Anforderung Wert
mindestens unterstützte Client- Windows Installer 5.0 unter Windows Server 2012, Windows 8, Windows Server 2008 R2 oder Windows 7. Windows Installer 4.0 oder Windows Installer 4.5 unter Windows Server 2008 oder Windows Vista. Windows Installer unter Windows Server 2003 oder Windows XP. Informationen zum mindestens von einer Windows Installer-Version erforderlichen Windows-Service Pack finden Sie unter den Windows Installer-Run-Time Anforderungen.
Zielplattform- Fenster
Header- msi.h
Library Msi.lib
DLL- Msi.dll

Siehe auch

AllowLockdownBrowse-

AlwaysInstallElevated

DisableBrowse-

Installationskontext-

LookupAccountName-

ProductCode-

SOURCELIST-

Quellresilienz-