【发布时间】:2021-09-03 11:09:53
【问题描述】:
我有一个 ASP.NET Core Web API 应用程序,这个 Web API 需要调用另一个使用 OAuth2 进行身份验证的第 3 方 API。需要通过传递client_id和client_secret来调用这个第3方API的/token端点,授权类型为client_credentials。然后使用收到的不记名令牌发出后续请求,以从 3rd-party API 检索数据。
根据我的研究,可以使用HttpClient 实现此要求,并从 .NET Core Web API 控制器(或理想情况下在控制器访问的服务类中)调用第 3 方 API。
我的问题是是否有另一种方法/更好的方法来实现这一要求?我对上述方法的一个担忧是它会为每个请求调用第三方/token 端点。是否可以在Startup.cs 类中做一些实现?
【问题讨论】:
-
我建议先阅读这篇文章Which OAuth2 0 flow should I use。在您选择最适合您需要的流程后,您可以创建一个从
HttpClient扩展的类ThirdPartyClient,并为您选择的身份验证流程附加逻辑。有了这个,您将拥有一个客户端来使用您可以在任何需要的地方注入的 3rd-party API。注意:在 Startup.cs 中只使用它来配置 DI 和必要的服务。
标签: c# asp.net-core asp.net-web-api oauth-2.0 oauth