コンテンツにスキップ
メインメニュー
メインメニュー
サイドバーに移動
非表示
案内
メインページ
最近の更新
未作成ページ
おまかせ表示
ヘルプ
MonoBook
検索
検索
ログイン
個人用ツール
ログイン
ログアウトした編集者のページ
もっと詳しく
投稿記録
トーク
「
ASP .NET Core Web APIのSwagger UIでトークン認証を使えるようにする
」を編集中
ページ
議論
日本語
閲覧
編集
ソースを編集
履歴表示
ツール
ツール
サイドバーに移動
非表示
操作
閲覧
編集
ソースを編集
履歴表示
全般
リンク元
関連ページの更新状況
特別ページ
ページ情報
警告:
ログインしていません。編集を行うと、あなたの IP アドレスが公開されます。
ログイン
または
アカウントを作成
すれば、あなたの編集はその利用者名とともに表示されるほか、その他の利点もあります。
スパム攻撃防止用のチェックです。 けっして、ここには、値の入力は
しない
でください!
Authorize属性が付いたWeb APIのデバッグをしたい。 == 設定 == Swagger UIを有効にする処理部分にAuthorizeボタンを表示する設定コードを追加する。 .NET 8.0だとProgram.csあたり。 <source lang="csharp"> var builder = WebApplication.CreateBuilder(args); builder.Services.AddEndpointsApiExplorer(); builder.Services.AddSwaggerGen(options => { options.AddSecurityDefinition("Bearer", new OpenApiSecurityScheme { Description = "Authorizeボタンで表示される入力ダイアログには以下の形式でトークンを貼り付けろ \"Bearer {token}\"", Name = "Authorization", In = ParameterLocation.Header, Type = SecuritySchemeType.ApiKey, Scheme = "Bearer" }); options.AddSecurityRequirement(new OpenApiSecurityRequirement { { new OpenApiSecurityScheme { Reference = new OpenApiReference { Type = ReferenceType.SecurityScheme, Id = "Bearer" } }, new string[] {} } }); }); </source> == 使い方 == 上記のコードを入れるとSwagger UIにAuthorizeボタン(鍵マーク)が表示されるようになる。 Authorizeダイアログには以下の形式でトークンを貼り付けてログインする。 先頭の「Bearer 」が重要でトークンだけ貼り付けても動かないぞ。 Bearer {token} == 動作確認 == Swagger UIでAuthorize属性が付いたWeb APIを呼び出してみる。 200が返ってくれば正常。 <source lang="csharp"> [ApiController] [Route("api/[controller]")] public class ExampleController : ControllerBase { [HttpGet, Route("hello")] [Authorize] //トークン認証が必要 public IActionResult Hello() { var userId = User.FindFirst(ClaimTypes.Name)?.Value; return Ok($"Hello,{userId}"); } } </source> おわり。 [[category: ASP .NET Core]]
編集内容の要約:
MonoBookへの投稿はすべて、他の投稿者によって編集、変更、除去される場合があります。 自分が書いたものが他の人に容赦なく編集されるのを望まない場合は、ここに投稿しないでください。
また、投稿するのは、自分で書いたものか、パブリック ドメインまたはそれに類するフリーな資料からの複製であることを約束してください(詳細は
MonoBook:著作権
を参照)。
著作権保護されている作品は、許諾なしに投稿しないでください!
このページを編集するには、下記の確認用の質問に回答してください (
詳細
):
1たす1は?(全角で入力してください)
キャンセル
編集の仕方
(新しいウィンドウで開きます)
本文の横幅制限を有効化/無効化