微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net-mvc – 如何使用ASP.NET 5 MVC保护Web API 6

我有一个很好的ASP.NET 5 / MVC 6应用程序并运行。基本上是为了这个目的,它只是你开始一个新项目时保持简单的普通示例应用程序。到目前为止我可以:

>注册用户
>登录
>注销
>保护页面(强制登录等)

现在,我想要的是为应用程序提供API机制来登录获取身份验证令牌。具体来说,我正在研究两个移动应用程序进行测试,一个使用Angular / Cordova,另一个使用Xamarin。

我看起来很高低,我似乎找不到一个例子,显示如何使这项工作。我到目前为止发现的每一个例子都假定用户将通过正常的Web表单/后期循环进行登录,然后被带到加载Angular的页面,并且认证令牌已经在浏览器中。

下面是MVC控制器的AccountController.cs文件的相关代码。我最终想要的是等效功能,但是来自纯API调用,允许Angular / Xamarin发送一个用户名/密码并获取身份验证令牌或失败。

// POST: /Account/Login
    [HttpPost]
    [AllowAnonymous]
    [ValidateAntiForgeryToken]
    public async Task<IActionResult> Login(Loginviewmodel model,string returnUrl = null)
    {
        ViewBag.ReturnUrl = returnUrl;
        if (ModelState.IsValid)
        {
            // This doesn't count login failures towards account lockout
            // To enable password failures to trigger account lockout,set shouldLockout: true
            var result = await SignInManager.PasswordSignInAsync(model.Email,model.Password,model.RememberMe,shouldLockout: false);
            if (result.Succeeded)
            {
                return RedirectToLocal(returnUrl);
            }
            if (result.RequiresTwoFactor)
            {
                return RedirectToAction("SendCode",new { ReturnUrl = returnUrl,RememberMe = model.RememberMe });
            }
            if (result.IsLockedOut)
            {
                return View("Lockout");
            }
            else
            {
                ModelState.AddModelError(string.Empty,"Invalid login attempt.");
                return View(model);
            }
        }

        // If we got this far,something Failed,redisplay form
        return View(model);
    }

使用ASP.NET MVC 6来保护Web API的推荐方法是什么?

解决方法

我认为安全WebApi2的推荐方法是通过授权服务器。授权服务器负责生成令牌。但是基于 this,基于OAuth2的授权服务器是Katana3的一部分,已从Asp.Net 5中删除

我认为你的应用程序不是一个实时应用程序,因为ASP.NET 5和MVC 6都没有在最后的发布阶段。所以如果你可以改变你的身份认证过程,你可以使用Thinktecture的IdentityServer3

多米尼克·贝尔(Dominick Baier)曾在The State of Security on ASP.NET 5 and MVC 6和IdSvr3上映。该博客具有到用于示例API控制器的Github存储库的链接以及API客户端。它还有一个MVC Web应用程序的示例。 And it can work with Asp.Net Identity.

更新:

如果这不适合你,你可以尝试AspNet.Security.OpenIdConnect.Server.请注意,它在Github上有开放的问题,所以你可能会遇到使用它的问题。还要注意它的依赖,特别是azureadwebstacknightly。

请注意,ASP.NET 5和MVC 6可能处于稳定的beta版本,但仍处于beta版本。它仍然可以改变。

此外,IdSvr3 v2.0可能在其最终版本中,但由单独的团队开发。而且它只在2周前才被发布,所以IM HO喜欢大多数软件,你可能会遇到可能错过测试的东西。请注意0​​7005,上周,tweeted关于IdSvr3的(v2.0)版本,所以看来他们赞同它。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


这篇文章主要讲解了“WPF如何实现带筛选功能的DataGrid”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“WPF...
本篇内容介绍了“基于WPF如何实现3D画廊动画效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这...
Some samples are below for ASP.Net web form controls:(from http://www.visualize.uk.com/resources/asp
问题描述: 对于未定义为 System.String 的列,唯一有效的值是(引发异常)。 For columns not defined as System.String, the only vali
最近用到了CalendarExtender,结果不知道为什么发生了错位,如图在Google和百度上找了很久,中文的文章里面似乎只提到了如何本地化(就是显示中文的月份)以及怎么解决被下拉框挡住的问题,谈
ASP.NET 2.0 page lifecyle ASP.NET 2.0 event sequence changed a lot since 1.1. Here is the order: App
静态声明: &#39; Style=&quot;position: relative&quot; AppendDataBoundItems=&quot;True&quot;&gt; (无 或 空 或
以下内容是从网络上搜集资料,然后整理而来的。不当之处,请不吝指教。(The following were from network, and edited by myself. Thanks in a
Imports System Imports System.Reflection Namespace DotNetNuke &#39;*********************************
Ok so you have all seen them: “8 million tools for web development”, “5 gagillion tools that if you