asp.net-mvc – 我可以从服务器端的持票令牌中检索userinfo – web api 2吗?
发布时间:2020-09-26 00:31:49 所属栏目:asp.Net 来源:互联网
导读:这是我的场景:我有一个MVC Web应用程序和Web API. Web应用程序调用web api以保存/检索服务器中的数据. 让我们说这是一个问答网站.现在我有一个API,如果我提供用户名,密码,它会给我userid.但是网站中还有其他区域,并且很容易检索其他用户的用户ID.我将userid
这是我的场景:我有一个MVC Web应用程序和Web API. Web应用程序调用web api以保存/检索服务器中的数据. 让我们说这是一个问答网站.现在我有一个API,如果我提供用户名,密码,它会给我userid.但是网站中还有其他区域,并且很容易检索其他用户的用户ID.我将userid保留在会话存储中,并在POST对象中将其发送到需要的地方.现在,任何用户都可以在会话存储中调整该用户ID,并且他们可以代表其他用户发布问题/答案. 我怎么能阻止这个?我正在思考但不确定这是否是可行解决方案的一种方法 – 我们可以从服务器端提供的承载令牌中检索用户ID吗? 解决方法当您使用资源所有者凭据流在Web API中建立基于令牌的身份验证时,以及使用[授权]将受保护的控制器归属时,您确实可以执行此操作.您将发送到此受保护端点的有效承载令牌将创建用户存储在其中的ClaimsPrincipal主体(标识)对象,您可以获得如下的用户名:[RoutePrefix("api/Orders")] public class OrdersController : ApiController { [Authorize] [Route("")] public IHttpActionResult Get() { ClaimsPrincipal principal = Request.GetRequestContext().Principal as ClaimsPrincipal; var Name = ClaimsPrincipal.Current.Identity.Name; var Name1 = User.Identity.Name; return Ok(); } } 有关这方面的更多详细信息,您可以阅读我关于此topic here的详细信息. (编辑:鲜蔬坊站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp.net – Tridion分析和个性化错误:用户不能为空.请确保
- ASP.NET 4的IIS和服务器操作系统要求
- asp.net core 实现一个简单的仓储的方法
- asp.net-mvc – 有什么技巧/技巧使用亚音速与Asp.Net MVC框
- asp.net-mvc – 如何将MVC 5 IdentityModels.cs移动到单独的
- asp.net中js+jquery添加下拉框值和后台获取示例
- asp.net – Umbraco CMS(.NET):加载xslt /用户控件的日志错
- asp.net – Request.Url.AbsoluteUri和重写的URL
- asp.net – “’Microsoft.Jet.OLEDB.4.0’提供程序未在本地
- iis-7.5 – 使用虚拟目录/应用程序在IIS中托管ASP.NET 5 We
推荐文章
站长推荐
- asp.net-mvc – 如何在RegularExpression中忽略大
- asp.net-mvc – 用于电子邮件创建和发送的ASP.Ne
- asp.net – jquery getJson没有将任何值传递给控
- asp.net-mvc – 为什么我在带有godaddy服务器的M
- asp.net – .NET Web API 2 OWIN承载令牌认证
- asp.net-mvc – 在ASP.NET MVC中的LinkButton
- 将ASP.NET应用程序本地化为普通话
- asp.net-mvc – MVC 5 OWIN登录声明和Antiforger
- asp.net – 单个应用程序中的多个母版页
- asp.net – 测试Oracle存储过程的最简单的方法
热点阅读