- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在努力使用 ASP.Net 成员资格/角色提供程序在 WCF 4.0 RESTfull 服务中进行用户名/密码身份验证/授权。
花了两天时间试图找到大多数人都同意的东西,我放弃了。很多困惑似乎是因为没有专门针对 WCF 4.0 的信息。
有人能善待吗
最佳答案
我认为您的问题的答案取决于您的服务的目的以及将要使用它的应用程序的类型。
如果您有一个现有的 ASP .Net 应用程序,并且希望将其部分功能公开为 RESTfull 服务,您将能够使用 AJAX 使用客户端,那么 WCF 可能不是最佳选择。在这种特殊情况下,您在 Web 应用程序中已经有一个身份验证用户,并且您希望在 AJAX 调用期间传播该身份验证。实现这一点实际上非常简单。
ASP .Net Forms 身份验证基于成功登录后生成并传递给浏览器的身份验证 cookie。浏览器对与您的应用程序位于同一域中的任何 URL 的每次调用也将包含身份验证 cookie。在 ASP .Net MVC 中,您可以简单地将服务方法实现为需要授权的 Controller 操作,一切都会在幕后为您发生。
在经典的 ASP .Net 中,您可以使用 PageMethods 来实现您的服务方法,并且会再次为您发送和验证 cookie(PageMethods here 和 here 的示例)。
另一方面,如果您的服务将在浏览器之外使用(例如从桌面或移动应用程序),那么 WCF 可能确实是实现该服务的正确工具。但是,ASP .Net 表单例份验证并不是实现安全性的最佳选择。 REST 服务的主要目的是简单,以便可以在每个平台上轻松实现客户端,并且 ASP .Net 表单例份验证的基于 cookie 的机制并不是最直接的。
OAuth 是一种专门为 Web 服务上下文中的用户身份验证而构建的协议(protocol)。它的第二个版本仍在草稿中(查找规范 here),但很可能这是您想要使用的版本,因为它比 OAuth 1.0 简单得多。 Facebook 已经通过 OAuth 2.0 实现了其 API 身份验证(详情 here ),您可能想查看他们的实现以获取灵感。
除了用户身份验证之外,OAuth 还确保使用应用程序(服务客户端)身份验证,并确保用户永远不会直接在客户端应用程序中输入其凭据。如果这比您实际需要的太多,您可以创建一个受 OAuth 2.0 启发的自定义实现。
首先,您需要通过 HTTPS 公开您的服务,以便对服务和客户端之间的所有通信进行加密。其次,您需要在服务中创建一个登录方法,如下所示:
string Login(string user, string password);
Employee[] GetAllEmployees(string authToken)
{
// verify token here
// return data if user authenticated by token
}
关于WCF 4.0 REST 用户名密码认证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7465120/
Internal Server Error: /admin/account/customuser/add/ Traceback (most recent call last): File "C:\
有问题!虽然我发现几乎相似的线程但没有帮助:( 我编写了一个 php 脚本来从我的 MySQL 数据库中获取注册用户的数量。该脚本在我的本地主机上运行良好;它使用给定的用户名、密码和主机名,分别是“r
我正在做一项基于密码的作业,我将 key 和消息放在单独的数组中。我想创建第三个数组,其中包含围绕消息大小的 key ,如下所示: message keykeyk 我已经在这个问题上苦苦挣扎了一段时间
我的几个客户要求我实现图形密码检查器,例如 关于如何实现这种 UI 有什么想法吗? 最佳答案 试着看看这个:https://code.google.com/p/android-lockpattern/
我正在使用 MAMP,每次登录 phpMyAdmin 时,都会收到以下错误/警告消息: the configuration file now needs a secret passphrase (bl
我正在尝试通过将 Visual Studio 2013 连接到我的测试机来调试 WDF 驱动程序。它创建一个名为 WDKRemoteUser 的用户,并在进行测试时尝试自动登录。有人知道这个用户的密码
使用具有指定用户名和密码的 SVN 提交。我希望服务器抛出错误;所以我可以告诉我的用户他/她的密码错误。 相反,在使用错误密码提交后: svn commit "test_file.txt" --use
我正在尝试实现 friend 推荐。 它从节点“你”开始。而且,我想找到节点“安娜”。 换句话说,这是我的两个或更多 friend 共同认识的人。上面的示例节点是 Anna。 如果您的帮助,我将不胜感
我都尝试过 wget --user=myuser --password=mypassword myfile 和 wget --ftp-user=myuser --ftp-password=mypass
我的一位用户提示说,每当他尝试使用默认管理界面(Django 的管理员)添加新用户(auth.User)时,新用户名和密码都会自动填充他自己的。 问题是他在登录时要求 Firefox 记住他的用户名/
我们正在开发一款应用(当然)用于应用购买 (IAP)。我已完成指南中的所有操作以启用 iap,并且一切正常,直到我想要购买为止。 部分代码: MainViewController.m -(vo
我试图创建两个可选匹配项的并集(如下所示),但我得到的不是并集,而是两者的交集。我应该如何更改此查询以获得所需的联合? optional match (a:PA)-[r2:network*2]-(b:
我想将Ansible用作另一个Python软件的一部分。在该软件中,我有一个包含其用户名/密码的主机列表。 有没有一种方法可以将SSH连接的用户/密码传递给Ansible ad-hoc命令或以加密方式
嗨,我在使用xampp的Apache Web服务器上收到错误500。直到我使用.htaccess,.htpasswd文件,错误才出现。我搜索了,但找不到语法错误。我只有1张图片和要保护的索引文件。以下
我一直使用它来编辑用户帐户信息: $this->validate($request, [ 'password' => 'min:6', 'password_confirmation'
我需要使用InstallUtil来安装C# Windows服务。我需要设置服务登录凭据(用户名和密码)。这一切都需要默默地完成。 有没有办法做这样的事情: installutil.exe myserv
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a software
如果我有一个随机的、16 个字符长的字母数字盐(不同大小写),它是为每个用户生成和存储的,我是否还需要一个站点范围的盐? 换句话说,这样好吗? sha1($user_salt . $password)
我正在开发一个空白程序,该程序将允许用户创建一个帐户,以便他们可以存储其余额和提款/存款。用户输入用户名和密码后,如何存储这些信息以便用户可以登录并查看其余额?我不一定要尝试使其非常安全,我只是希望能
我正在尝试寻找一种通用方法来搜索没有链接到另一个节点或节点集的节点或节点集。例如,我能够找到特定类型(例如 :Style)的所有节点,这些节点以某种方式连接到一组特定的节点(例如 :MetadataR
我是一名优秀的程序员,十分优秀!