- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在学习使用 AngularJS 前端框架开发 asp.net Web API。大约一个星期以来,我一直在对此进行大量研究。我已经阅读了有关 oauth 2、owin 和其他内容的信息。但现在很困惑哪个更好。
我有几个问题,希望你们能帮助我。
1) 在我的应用程序中 - 只有注册用户才能通过使用电子邮件和密码登录来访问应用程序。有人可以给我指出一个好的资源或文章,介绍如何使用 API 创建良好的注册和登录身份验证。这足够安全,因为我将收集用户数据并存储它们。
2) 我需要什么类型的安全性来保护我的 API,起初 API 会在防火墙后面,然后一个项目完成后它将向世界开放?如果可能的话,请指出正确的方向。
请注意,这不是一个重复的问题,我已经浏览了 stackoverflow 上的大部分帖子,并在找不到答案后提出这个问题。
对此有任何建议或帮助,我们将不胜感激。
感谢您为此主题所做的所有努力
最佳答案
您可以使用 Asp.Net Web API 2、OWIN、Asp.Net Identity 和 AngularJS 使用基于 token 的身份验证。
Asp.Net Web API 现在完全支持 OWIN。 Katana 是微软的 OWIN 实现。
Asp.Net Web API 现在支持使用 OAuth 2.0 进行授权。 Microsoft OWIN 组件使 OAuth 成为可能。
您是否对 Identity、OWIN、OAuth 这些术语感到困惑...这里是对它们的简要概述。
Asp.Net Identity 是为了克服asp.net 成员(member)系统的问题而开发的。 Asp.Net Identity 允许我们使用不同的存储(表存储,无 SQL),并允许我们使用外部身份提供者,因为它使用 OWIN。
OWIN 旨在打破 Asp.Net 和 IIS 之间的紧密耦合。 OWIN 只是一个规范。 Katana 是 Microsoft 的 OWIN 实现。 OWIN 位于 http 请求管道中。 OWIN 管道有中间件组件,我们可以在其中提及外部登录机制。
OAuth 的创建是为了消除用户与第三方应用程序共享密码的需要。
注意:这里 Asp.Net Identity 与 OWIN、OAuth 无关,反之亦然。它们是三个独立的概念。 Asp.Net Identity 是微软的实现。 OWIN、OAuth 是开放的标准概念。因为 Microsoft 已经实现了 OWIN,所以 OAuth 成为可能。
因此,Web API 2 使用 OAuth 不记名 token 而不是表单例份验证 cookie,这在 Web API 世界中更为正确。因为它允许使用各种终端用户设备,例如移动设备。
对于您的情况,您可以使用 visual studio 2013 中提供的默认模板。
1. 新建工程,选择Asp.Net web application。
2. 选择Web API 或SPA 模板。
3. 更改身份验证并选择个人用户帐户。
4. 单击确定。
现在,一切都已默认配置,以便使用 OWIN、Asp.Net Identity、OAuth。由于我们使用基于 token 的身份验证,您会发现帐户 Controller 中没有可用的登录方法。
当您使用很棒的前端框架 AngularJs 时,您可以将不记名 token 保存在本地存储中,并且您可以编写一个 http 拦截器服务,它负责为每个请求发送不记名 token 。
此处用户注册由 Asp.Net 身份负责,而用户身份验证由 OAuthAuthorizationServer 负责,OAuthAuthorizationServer 默认存在于 Providers 文件夹中。
我们收到的不记名 token 不是针对特定客户端的,因此任何人都可以拦截它们。因此只能通过 SSL 使用它们。
请通过此链接
http://www.asp.net/web-api/overview/security/individual-accounts-in-web-api http://bitoftech.net/2014/06/09/angularjs-token-authentication-using-asp-net-web-api-2-owin-asp-net-identity/
关于c# - 使用 Restful asp.net Web api 和安全 API 进行用户登录身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25374861/
我有一个几乎可以构建的Maven / Grails应用,但在web.xml上找不到[my-app]\webapp\WEB-INF\web.xml。但是目录结构像往常一样包含web-app文件夹,而不是
正如我在标题中提到的:我想知道 web-service 和 web-socket 之间的区别?我们什么时候使用每一个? 谢谢! 最佳答案 一个web service是一个响应客户端 SOAP/REST
让我们看一个示例场景: 客户端打开一个网站并找到他从文本框中输入的两个数字的总和。然后单击“添加”按钮。两个参数通过 HTTP GET 发送到服务器,在服务器上写入 PHP 代码以添加数字,结果为回声
我知道这是一个老问题,肯定已经被回答了数百次,但我还无法找到令人满意的答案。 我正在创建一个应用程序,其他应用程序(移动/网络)将使用该应用程序来获取数据。现在我有两个选择: 将我的应用程序创建为简单
通过 Web 作业部署新功能有 3 种方法: 创建一个新的 Web 应用,并部署一个包含该函数的 Web 作业。 向现有 Web 作业添加一项新函数(这样您现在在一个 Web 作业中就拥有了多个函数)
我收到来自网络场景的通知,上面写着“问题”和“确定”。我想在问题发生时包含网络响应的内容。我不担心标题值,只担心网页的内容. 这是我可以在通知设置中引用的变量吗? 最佳答案 不幸的是 zabbix 不
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
嗨,这是一个理论问题,但我真的无法弄清楚 Web 应用程序、基于 Web 的应用程序和基于云的应用程序之间的区别。这个你能帮我吗。 最佳答案 @Matt 是对的 - 这真的无关紧要,但是,为了清楚起见
我正在尝试使用多个 Web 服务,这些服务在它们的 wsdl 中重新定义了一些相同的公共(public)类。我目前在网站中引用了它们,但我想转换为 Web 应用程序。 由于一些相同的类是从多个 Web
一个。我必须考虑哪些事项?b.当前应用程序正在执行多个存储过程。如果我创建等效的方法来执行这些过程,会有什么风险或挑战。 最佳答案 在架构上,将网络应用程序转换为网络服务时必须考虑的一件事是,对方法和
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 5年前关闭。 Improve thi
网络 API 和网络服务之间有什么区别吗?或者它们是同一个吗? 最佳答案 网络服务通常提供 WSDL您可以从中自动创建客户端 stub 。 Web 服务基于 SOAP protocol 。ASP.NE
我已经获得了我需要的所有资源。我将 Web 服务放入应用程序服务环境中,然后将 NSG 连接到应用程序服务环境使用的子网。然后,我允许 VNET 内的应用程序与 Web 服务进行通信,但它无法正常工作
我已经获得了我需要的所有资源。我将 Web 服务放入应用程序服务环境中,然后将 NSG 连接到应用程序服务环境使用的子网。然后,我允许 VNET 内的应用程序与 Web 服务进行通信,但它无法正常工作
我正在使用 stub 将我的网络服务相关测试与实际网络服务隔离开来。 你/我应该如何合并测试以确保我制作的响应与实际的网络服务匹配(我无法控制它)? 我不想知道怎么做,而是何时何地? 我应该为测试数据
我在互联网上搜索了很多,但我仍然没有得到网络服务和网络 API 之间的明显区别?我在某处读到所有 Web 服务都是 API,但所有 API 都不是 Web 服务。如何? 我所知道的是两者都允许利用其他
假设我已经完成了使用 JavaEE 制作的 Web 应用程序。这个 Web 应用程序包含登录系统,但最后它是非常基本的 Web 应用程序。我使用的是 GlassFish 3.1.2.2。 我想知道一旦
我希望设计者能够打开与我相同的解决方案文件。这可以通过 Expressions Web 实现吗? 最佳答案 简短的回答是“不”;但这是一个非常常见的请求,我知道很多人都希望下一个版本(无论何时)对此有
我正在尝试在 CF10 中创建一个 Web 服务对象。我已验证它在 SoapUI 中按预期工作。但是,当我在 CF 中运行它时,我得到一个错误,它无法找到在 WSDL 的导入语句中导入的 XSD。这是
我的要求是开发一个 Web 服务,充当外部 Web 服务和客户端之间的中间人。 我知道,我可以为我的服务设计一个wsdl,然后将外部wsdl映射到代码中我的wsdl。我的问题是有一个开源 api/工具
我是一名优秀的程序员,十分优秀!