flash - WCF 中基于 token 的身份验证

标签 flash wcf authentication token system.security

我正在创建一个包含 ASP.NET 页面和 Flash 小程序的网站。我想将我的业务逻辑封装在 WCF 服务中,该服务将通过两个端点公开:一个可通过 HTTP(S) 通过 Internet 访问,供 Flash 客户端使用,另一个可在数据中心内访问,供应用程序服务器使用.如果这看起来不是一个好方法,那么请阻止我;否则,我会继续...

问题是如何验证来自 Flash 客户端的请求。由于我不想将用户的密码存储在浏览器 cookie 中,不想在每次请求时都发送密码,也不想在初次登录后使用 HTTPS,我打算使用 token ——基于身份验证的系统。我也不希望用户在已经登录到站点本身后必须登录到 Flash 客户端,因此我计划在 Flash 客户端启动时使用 Javascript 将 token 传递给它。

我知道 WCF 支持使用 .NET Framework 的内置安全框架 (System.Security) 来实现访问控制,我想利用这一点。

那么问题来了:当 WCF 服务被 Flash 调用时,如何将 token 传递给 WCF 服务,以及如何在服务器上处理 token ?

  • WCF 有一个“颁发的 token ”身份验证模式,但它似乎旨在用于具有安全 token 服务和 SAML token 的成熟的联合方案——我真正想要的有点复杂。可以将这种模式与我自己的“简单随机字符串” token 一起使用吗?如果是这样,如何?请记住,这需要与 Flash 兼容。
  • 我可能会在 header (SOAP header 或 HTTP header )中传递 token 。在这种情况下,一旦我确定了哪个用户发出请求,我该如何通知框架以便 System.Security 检查起作用?
  • 我应该考虑完全不同的方法吗?任何避免在每个请求中都发送密码、让我使用 System.Security 并与 Flash 一起工作的东西都是可能的。
  • 最佳答案

    由于似乎原始问题已得到解答,我将保持简短,但一种方法确实是在 http header 中传递身份验证 token 并覆盖 CheckAccess(OperationContext operationContext, ref Message message)在自定义 ServiceAuthorizationManager .

    您之前已将服务配置为使用实现 IAuthorizationPolicy 的自定义策略。 .

    剩下的就是实现简单的IIdentityIPrincipal类来存储您的授权状态。

    关于这个主题有很多好文章:

    http://msdn.microsoft.com/en-us/library/system.identitymodel.policy.iauthorizationpolicy.aspx

    http://msdn.microsoft.com/en-us/library/system.servicemodel.serviceauthorizationmanager.aspx

    我想这可能仍然感觉像是一个“自己动手”的解决方案,但是当您遵循既定的模式时,它至少让人放心。它确实具有将您的授权代码从您的服务方法中黑盒化的优点。

    关于flash - WCF 中基于 token 的身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1861868/

    相关文章:

    flash - 动态文本 - 自动调整字体大小

    c - 添加 WCF 服务引用时出错?

    authentication - Google oauth2 在每次登录时显示批准提示

    android - Web 服务 Http 身份验证 - Android 上的 KSOAP2

    actionscript-3 - flash as3 - 我需要在 byteArray 数据中进行二进制搜索

    arrays - AS3中的多维数组排序

    apache-flex - Flex/Flash 可以录屏吗?

    c# - 设置属性时获取 StackOverflowException

    c# - WCF认证

    java - Android 在 X 次尝试失败后阻止登录