1. vs code 終端執行 dotnet new webapi --name ClientCredentialApiweb
2. 找到ValuesController.csapi
引用 using Microsoft.AspNetCore.Authorization;app
[Authorize] [Route("api/[controller]")] [ApiController] public class ValuesController : ControllerBase { }
3. Nuget 導入 IdentityServer4.AccessTokenValidationui
4. 修改 Startup.cs this
using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Microsoft.AspNetCore.Builder; using Microsoft.AspNetCore.Hosting; using Microsoft.AspNetCore.HttpsPolicy; using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; using Microsoft.Extensions.Options; namespace ClientCredentialApi { public class Startup { public Startup(IConfiguration configuration) { Configuration = configuration; } public IConfiguration Configuration { get; } // This method gets called by the runtime. Use this method to add services to the container. public void ConfigureServices(IServiceCollection services) { //註冊Authentication services.AddAuthentication("Bearer").AddIdentityServerAuthentication(options => { options.Authority = "https://localhost:5000"; options.RequireHttpsMetadata = false; options.ApiName = "api"; }); services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1); } // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. public void Configure(IApplicationBuilder app, IHostingEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } else { app.UseHsts(); } app.UseHttpsRedirection(); app.UseAuthentication(); app.UseMvc(); } } }
5. 啓動 " IdentityServer4 登錄中心服務 " ,使用PostMan 調用 http://localhost:5003/connect/tokenspa
參數code
client_id:client
client_secret:secrt
grant_type:client_credentialsblog
6. 把當前項目也啓動,進行驗證 , 客戶端驗證整個過程沒有任何毛病token