Freigeben über


Permission.ReadAsync Methode

Definition

Liest eine PermissionProperties aus dem Azure Cosmos-Dienst als asynchronen Vorgang. Jeder Lesevorgang gibt einen neuen ResourceToken mit dem jeweiligen Ablauf zurück.

public abstract System.Threading.Tasks.Task<Microsoft.Azure.Cosmos.PermissionResponse> ReadAsync (int? tokenExpiryInSeconds = default, Microsoft.Azure.Cosmos.RequestOptions requestOptions = default, System.Threading.CancellationToken cancellationToken = default);
abstract member ReadAsync : Nullable<int> * Microsoft.Azure.Cosmos.RequestOptions * System.Threading.CancellationToken -> System.Threading.Tasks.Task<Microsoft.Azure.Cosmos.PermissionResponse>
Public MustOverride Function ReadAsync (Optional tokenExpiryInSeconds As Nullable(Of Integer) = Nothing, Optional requestOptions As RequestOptions = Nothing, Optional cancellationToken As CancellationToken = Nothing) As Task(Of PermissionResponse)

Parameter

tokenExpiryInSeconds
Nullable<Int32>

(Optional) Die Ablaufzeit für das Ressourcentoken in Sekunden. Dieser Wert kann zwischen 10 Minuten (oder 600 Sekunden) und 24 Stunden (oder 86.400 Sekunden) liegen. Der Standardwert hierfür ist 1 Stunde (oder 3.600 Sekunden). Dadurch wird der Standardwert für zukünftige Token nicht geändert.

requestOptions
RequestOptions

(Optional) Die Optionen für die Berechtigungsanforderung.

cancellationToken
CancellationToken

(Optional) CancellationToken stellt die Anforderungsabbruch dar.

Gibt zurück

Eine Task , die einen PermissionResponse enthält, der einen PermissionProperties umschließt, der den Leseressourcendatensatz enthält.

Ausnahmen

Diese Ausnahme kann viele verschiedene Fehlertypen kapseln. Um den spezifischen Fehler zu ermitteln, sehen Sie sich immer die StatusCode-Eigenschaft an. Einige häufige Codes, die Sie beim Erstellen einer Berechtigung erhalten, sind:

StatusCodeAusnahmegrund
404NotFound: Dies bedeutet, dass die Ressource oder die übergeordnete Ressource, die Sie lesen möchten, nicht vorhanden war.
429TooManyRequests: Dies bedeutet, dass Sie die Anzahl der Anforderungseinheiten pro Sekunde überschritten haben. Lesen Sie den Wert DocumentClientException.RetryAfter, um zu ermitteln, wie lange Sie warten sollten, bevor Sie diesen Vorgang wiederholen.

Beispiele

User user = this.database.GetUser("userId");
Permission permission= user.GetPermission("permissionId");
PermissionProperties permissionProperties = await permission.ReadAsync(tokenExpiryInSeconds: 9000);

Gilt für: