我被指派寻找在我们的产品中实施 SSO 的方法。我们有几个 Winform 应用程序和一个 asp.net 4.0 Web 应用程序(不是 MVC)。
所有产品均使用 .Net 4.0 构建,Web 应用程序为 ASP.NET 4.0。一些 Winforms 通过 Web 服务 (asmx) 与我们的 API 通信,一些直接使用我们的 API。Web 应用程序也使用相同的 API。我们为外部客户端提供一组使用相同 API 的 Web 服务 (asmx)。
目前,我们的系统中有自己的身份验证实现(用户、密码、角色),我们希望将其替换为 SSO。或者这两种身份验证机制能否以某种方式共存?Winforms 用于 Intranet,Web 应用程序用于 Intranet,我们还为客户端托管 Web 应用程序(可从 Internet 访问)。
用户是在我们的系统中创建的,但同时我们使用我们自己的工具从 Active Directory 导入用户。Active Directory 是真正的主要用户来源。
我已阅读有关 Windows Identity Foundation 的信息,我想知道是否可以使用它来实现 SSO。但是我不明白的是,当他们直接使用API时,如何在winform应用程序中使用WIF。
我想要实现的是从我们的系统中删除所有用户管理并使用 Active Directory 作为用户源。我想这意味着使用 ADFS 2.0 创建声明等。
我可以在这个实现中使用 .Net Framework 4.5(我知道 WIF 现在是 .Net Framework 4.5 中的一等公民)。
你有什么建议如何做到这一点?WIF 是跨 winforms 应用程序和 Web 应用程序实现 SSO 的最佳替代方案吗?