認証
このページの翻訳はAIによって自動的に行われました。可能な限り正確な翻訳を心掛けていますが、原文と異なる表現や解釈が含まれる場合があります。正確で公式な情報については、必ず英語の原文をご参照ください。
Sitecore Content Hubでは、セキュリティのためにOAuth 2.0承認フレームワークを使用します。</ OAuthは、アクセス委任のオープンスタンダードであり、インターネットユーザーがWebサイトやアプリケーションに他のサイト上の情報へのアクセスを許可する方法として一般的に使用されていますが、これらのWebサイトやアプリにパスワードを与えることはありません。OAuth 2.0は、Webアプリケーション、デスクトップ アプリケーション、携帯電話、およびスマート デバイスの認証フローを提供します。
Content HubでOAuthを設定する
Content HubでOAuthを設定するには:
-
メニュー バーで、Manage
をクリックします。 -
Manageページで、「OAuth clients」をクリックします。
-
「
OAuth Client」をクリックします。 -
OAuth Clientダイアログで、次のプロパティを入力します。
-
Name
-
Client ID
-
Client Secret
-
Redirect Url
-
-
Client Typeドロップダウンリストから、Client Credentialsをクリックします。
-
UsersフィールドでAdd
をクリックし、Userダイアログでユーザーを選択してからSaveをクリックします。 -
OAuth Clientダイアログで、「Save」をクリックします。
OAuthクライアントを編集するには、編集するクライアントの横にあるQuick Edit
をクリックします。クライアントを削除するには、Delete
をクリックします。
パスワード認証
ClientIdとClientSecretに加えて、プロジェクトからのContent Hubで認証するためのユーザー名とパスワードを指定します。これらの値は、IWebMClientインスタンスを構築するために必要です。次に、Content Hub認証の例を示します。
クライアント資格情報の認証
クライアントは、Client typeをClient credentialsに設定して作成する必要があります。
Content HubでOAuthを設定すると、Usersフィールドに複数のユーザーを定義できます。ただし、認証の目的では最初のもののみが使用され、これはすべての操作がそのユーザーのコンテキストで実行されることを意味します。
また、OAuthクライアントで使用する専用のサービスユーザーアカウントを作成して、サービスによって実行される操作が個々のユーザーアカウントにリンクされないようにすることもできます。
次のコードは、クライアント資格情報の認証の例を示しています。
更新トークン認証
リフレッシュ・トークン認証は、usernameおよびpassword認証の代わりに使用できます。「Refresh token authentication」では、IWebMClient.RefreshTokenReceivedイベントに加入することが大切です。OAuthPasswordGrantを作成する代わりに、これを次のように変更OAuthRefreshTokenGrant
更新トークンを取得するには、REST APIのドキュメントを参照してください。
更新トークンが変更されると、古いトークンは無効になります。常に最新の更新トークンを追跡してください。
構成をテストする
認証クライアントを作成した後、TestConnectionAsyncを呼び出して設定をテストできます。これにより、エラーの原因 (存在する場合) を説明する例外がスローされます。
このメソッドは、次の要素をチェックします。
-
サーバーが動作しているかどうか
-
クライアントがサーバーに正常に接続できるかどうか
-
SDKとサーバーがバージョン互換性があるかどうか
-
資格情報が正しいかどうか
コンソール アプリケーションのデフォルトのMainは、C# 7.1より前の非同期操作をサポートしていませんでした。C# のバージョンが7.0より前の場合は、メソッド呼び出しに .Wait() ( voidを返す場合) または .Resultを追加し、awaitキーワードを削除する必要があります。例えば:
それ以外の場合、asyncをサポートするために、署名を次のように変更します。
テスト接続方法の詳細については、APIリファレンスを参照してください。