我正在创建一个包含 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 ?
最佳答案
由于似乎原始问题已得到解答,我将保持简短,但一种方法确实是在 http header 中传递身份验证 token 并覆盖 CheckAccess(OperationContext operationContext, ref Message message)
在自定义 ServiceAuthorizationManager
.
您之前已将服务配置为使用实现 IAuthorizationPolicy
的自定义策略。 .
剩下的就是实现简单的IIdentity
和 IPrincipal
类来存储您的授权状态。
关于这个主题有很多好文章:
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/