asp.net-web-api C ASP身份OAuth令牌 C 我应该在移动应用流程中使用ValidateClient
我已经实现了令牌流认证(在
Taiseer’s guide的帮助下).
还有一个我无法理解的概念:CleintId和ClientSecret.
据我所知,
|
我有一个移动应用程序,它与后端的ASP WebAPI进行通信.
还有一个我无法理解的概念:CleintId和ClientSecret. 据我所知,客户端秘密(以及客户端ID)意味着 意思是,只有拥有秘密的客户才能启动认证流程.在我的情况下,我只有一个客户端是一个移动应用程序,它的秘密存储在一个安全的地方(KeyChain for iOs).但我已经读到,这些钥匙链可以很容易地被倾倒并解剖秘密. 所以我想出的结论是,我可以摆脱整个客户端的秘密逻辑,主要是将ValidateClientAuthentication()留空: public async override Task ValidateClientAuthentication(OAuthValidateClientAuthenticationContext context) { context.Validated(); return; }而对我而言,这似乎不是一个安全漏洞,而是流动中的一层薄薄的现在消失了.因为,任何持有安装了应用程序的移动设备的恶意用户都可以轻松地揭示客户机密,并且一旦获得它,这层安全就没用了. 这些假设是不正确的? 我可以将ValidateClientAuthentication()方法留空吗? 解决方法 正如您已经想到的那样,移动应用程序无法将其凭据保密,因为它们可以从应用程序二进制文件中提取.更不用说使用代理服务器和流量分析器(如Fiddler或Wireshark)可以轻松拦截请求.使用授权代码流(1)或资源所有者密码凭据授予,如果客户端无法安全地存储其凭据,则客户端身份验证不是必需的,因此不能将其视为“机密”应用程序(请参阅http://tools.ietf.org/html/rfc6749#section-4.1.3和http://tools.ietf.org/html/rfc6749#section-4.3.2). 对于非机密应用程序,可以安全地调用context.Validated(). 就个人而言,我尽可能地避免资源所有者密码凭证授予,因为它明显违背了OAuth2的目的:保密密码并提供受限制的授权.如果您的应用程序完全受信任,那么它应该不是问题. >实际上,使用授权代码流而不强制执行客户端身份验证是非常罕见的,因为使用移动客户端应用程序的隐式流更简单,在这种情况下提供类似的安全级别(更不用说它避免了第二次往返)令牌端点). (编辑:东莞站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- asp.net – 使用FormsAuthentication持久的cookie超时
- asp.net – 在为app_offline.htm提供特定URL时,将http状态5
- ASP.NET MVC 4 JSON绑定到视图模型 – 嵌套对象错误
- asp.net – 按钮属性: – commandName和CommandArguments
- asp.net-mvc-3 – 方法“OrderBy”必须在方法“跳过”异常之
- asp.net-mvc – 如何在ASP.NET MVC中生成弹出页面链接
- asp.net – 如何在selectindexchanged下拉列表后避免页面刷
- ASP.NET MVC编辑器模板和Html.EditorFor(…) – 如何消除类
- asp.net-mvc – 保存后显示相同的页面
- asp.net – “线程被中止了什么”. ‘SNIReadSync(SNI_Conn
- 如何在asp.net中更改javascript警告框的标题?
- asp.net-mvc – MVC 5 OWIN登录声明和Antiforger
- asp.net-mvc – 我可以获取html.HiddenFor / Htm
- 将ASP.NET身份与核心域模型分离 – 洋葱架构
- asp.net-mvc – 在MVC命令,优先级和功能问题中授
- asp.net – 无法加载类型’site._Default[已关闭
- asp.net-mvc – ASP.NET MVC现在是“开源”.这是
- asp.net – 适用于多个用户的EWS通知中心
- asp.net-mvc – 当我不知道内容类型时如何返回文
- asp.net 文件上传实例汇总
- asp.net-core C 如何使用ASP.NET注册OData
- asp.net C MVC4 C ContextDependentView C
- asp.net-mvc-3 C 如何从ASP.NET MVC#输出中
- asp.net-mvc C 使用AD的ASP.NET MVC表单Aut
- asp.net-mvc C 未在ELMAH中记录的错误
- asp.net-mvc-4 C 在EF迁移配置类的Seed方法
- asp.net-mvc C 已经使用相同的参数类型定义
- ASP.Net C AJAX UpdatePanel中的Javascript
- asp.net-mvc C MVC应用程序中的随机数生成
- asp.net-mvc C ASP.NET MVC中的WebApi [Fro
