- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 asp.net Web api 创建 REST 服务,一切工作正常,但我现在遇到了如何进行身份验证。
我有点困惑从哪里开始,这就是我一直在想的。
我有一个由许多资源组成的 REST api,每个资源都需要用户注册,那么执行此操作的最佳操作是什么?我是否应该在每次调用服务时在 header 中发送用户名和密码,以便我可以使用在服务器上进行身份验证
AuthorizationFilterAttribute
我至少应该加密它?我有兴趣知道其他人在做什么,我知道有一个创建 token 的概念(我认为它是短暂的),因此用户将进行身份验证,然后会收到一个 token ,然后该 token 将被发送进一步调用该服务。那么当token过期时我该如何处理呢?
我还有一个用于注册新用户的资源,实际上唯一调用此资源的是我的客户端(Android、iPhone)。那么我是否应该让它不包含任何身份验证方法,或者设置硬编码密码或类似的内容,以便至少没有其他人可以注册新用户?请记住,该服务将在互联网上公开。
我似乎无法找到正确的方法来做到这一点,我当然想尝试第一次就做对,这样我就不必完全重构服务。
最佳答案
以下链接似乎涵盖了一些明智的 DIY 选项 http://codebetter.com/johnvpetersen/2012/04/02/making-your-asp-net-web-apis-secure/ 。 “基于公钥/私钥的 token ”部分涵盖了我过去有效使用的一种方法,也许会对您有所帮助。
目前虽然我正在使用 http://identityserver.codeplex.com/带有 OAuth 持有者 token (“资源所有者密码凭证”授予类型)的 Thinktecture IdentityServer...我发现这是一组非常好的代码和示例,可以让 IOS 客户端获取 token 并调用 WebApi。
如果您确实必须保护您的注册屏幕,您可以使用设备上安装的客户端证书进行身份验证...Thinktecture 服务再次可以在这里提供帮助 https://identity.thinktecture.com/idsrv/docs/default.htm?RequestingatokenusingOAuth2.html 。尽管如果您的注册过程是安全的What are best practices for activation/registration/password-reset links in emails with nonce例如电子邮件确认和激活等。公开访问可能是安全的 - 这一切都取决于您的业务需求和所需的注册工作流程。
您至少应该使用传输级别安全性 SSL,但正如您建议的消息级别安全性,例如加密任何 token 是非常明智的 - OAuth 规范对此有话要说 http://self-issued.info/docs/draft-ietf-oauth-v2-bearer.html#mitigation .
关于过期 token - 我们倾向于以与密码更改政策相同的频率使 token 过期;尽管保持有效时间较短很重要(以最大限度地减少 token 盗窃的影响),并且需要考虑平衡您的要求。 OAuth有刷新 token 的概念Why Does OAuth v2 Have Both Access and Refresh Tokens?这里有一些围绕这个主题的争论和链接,我们目前没有使用这种方法,因为我们使用的 ID 服务器目前不支持这种方法。
保证您的代币安全也是一个考虑因素,例如我们在 IOS 中使用 KeyChain,但如果可能的话,还要考虑移动设备管理策略,就好像这些 token 或密码是可能被盗的设备之一,或许可以考虑越狱检测、锁屏强制执行等。
关于ASP.NET Web Api (REST) : Authentication using the users credentials or a token? 保留 "Register new user"资源密码吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11378046/
我在服务器端实现了 oauth token ,但在无效 token 或 token 过期时,我收到 200 http 状态代码,但在响应正文中我有{"code":"4XX", "data":{"som
我正在尝试将 sinatra-authentication gem 添加到 Sinatra 应用程序中,虽然它在那里并完成了它的一部分工作,但由于某种原因,路由似乎没有被添加。代码基础: requir
我有一个健身移动应用程序的想法,我一直在为 iPhone(基于 Obj-C)、Android(基于 Java)、WebOS(基于 html5)和诺基亚 Qt 开发基于这个想法的应用程序。 我现在需要向
我见过有人使用 UUID 生成身份验证 token 。然而,在 RFC 4122据说 Do not assume that UUIDs are hard to guess; they should n
上下文如下。 pouchdb-authentication API没有为此提供明确的方法。我考虑过使用db.getUser(username [, opts][, callback]) 。然而,该方法
Edge 浏览器中的“基本身份验证”没有保存密码的选项。当浏览器关闭并重新打开时,用户必须重新输入密码。 有没有人解决这个问题? 最佳答案 它仍然存在并且仍在工作,他们只是从那些对话框窗口中删除了复选
嗨,我需要知道如何在 iPhone 上使用 oAuth for twitter 自动登录帐户。该应用程序应登录并向用户显示该帐户的提要。 最佳答案 OAuthentication 需要几个阶段,您可以
Edge 浏览器中的“基本身份验证”没有保存密码的选项。当浏览器关闭并重新打开时,用户必须重新输入密码。 有没有人解决这个问题? 最佳答案 它仍然存在并且仍在工作,他们只是从那些对话框窗口中删除了复选
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
在尝试运行一些 OpenVAS CLI 命令时,我收到 Failed Authentication 错误消息。 OpenVAS 安装在 CentOS 机器上。我尝试使用用户帐户凭据,但仍然收到相同的错
我正在设计一个 web api。我需要让用户对自己进行身份验证。我有点犹豫让用户以明文形式传递他们的用户名/密码.. 类似于:api.mysite.com/auth.php?user=x&pass=y
我尝试通过 oAuth 在 Spring Security 应用程序中验证用户。我已经收到 token 和用户数据。 如何在没有密码和经典登录表单的情况下手动验证用户? 谢谢你。 最佳答案 像这样的东
我正在 Symfony 4 中创建一个简单的登录身份验证系统并使用安全组件 Guard。我的 FormLoginAuthenticator 如下: router = $router;
我正在开发一个具有多个角色的网络应用程序。我想到了一种方法,可以使用 React Router 通过 onEnter 触发器来限制对某些路由的访问。 现在我想知道这是否是防止访问未经授权的页面的可靠方
我已通读 RFC 2617如果支持多种方案,则无法在那里或其他任何地方找到分隔符。例如,假设支持 Basic 和 Digest。我知道它可能会以这种方式出现: HTTP/1.1 401 Unautho
我在 OWIN Cookie 身份验证方面遇到了一些问题。我有一个 .Net 站点,它有一些 MVC 页面,这些页面使用 cookie 身份验证和受不记名 token 保护的 WebAPI 资源。 当
我正在使用 Telnet 向 Mikrotik 路由器发送命令。 telnet 192.168.100.100 -l admin Password: pass1234 [admin@ZYMMA] >
我管理着一个庞大而活跃的论坛,但我们正被一个非常严重的问题所困扰。我们允许用户嵌入远程图像,就像 stackoverflow 处理图像 (imgur) 的方式一样,但是我们没有一组特定的主机,可以使用
这个真的让我抓狂。 我在 JBoss AS 中有一个 Guvnor(稍后会详细介绍)。我编辑了 components.xml 以启用身份验证(使用 JAAS,我已经很好地设置了用户和密码)和基于角色的
我们有一个管理站点,需要身份验证才能访问。站点上的页面包裹在 Coldfusion 自定义标签中,其中包括所有样式和 JS,以及一些其他信息。 我最近制作了一份自定义标签包装器的副本。我将副本放在与原
我是一名优秀的程序员,十分优秀!