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

在ASP.NET MVC中模拟User.Identity

我需要为一个ASP.NET MVC 2.0网站创建单元测试。该网站使用Windows身份验证。

我一直在阅读模拟处理HttpContext的代码的HTTP上下文的必要性。我觉得我也开始在DI模式上得到一个句柄。 (给类一个类型为IRepository的属性,然后在实例化控制器时传递Repository对象。)

然而,我不明白,是通过User.Identity Mock可用的Windows Principal对象的正确方法。这是HttpContext的这一部分吗?

任何机构都有一个链接一个文章,演示这个(或一本书的建议)吗?

谢谢,

Trey Carroll

解决方法

我已经使用IoC来抽象这一点与一些成功。我首先定义了一个类来表示当前登录用户
public class CurrentUser
{
    public CurrentUser(IIdentity identity)
    {
        IsAuthenticated = identity.IsAuthenticated;
        displayName = identity.Name;

        var formsIdentity = identity as FormsIdentity;

        if (formsIdentity != null)
        {
            UserID = int.Parse(formsIdentity.Ticket.UserData);
        }
    }

    public string displayName { get; private set; }
    public bool IsAuthenticated { get; private set; }
    public int UserID { get; private set; }
}

它需要一个IIdentity在构造函数中设置其值。对于单元测试,您可以添加一个构造函数,以允许绕过IIdentity依赖关系。

然后我使用Ninject(选择你最喜欢的IoC容器,没关系),并创建了一个IIdentity的绑定:

Bind<IIdentity>().ToMethod(c => HttpContext.Current.User.Identity);

然后,在我的控制器里面我声明在构造函数中的依赖:

CurrentUser _currentUser;

public HomeController(CurrentUser currentUser)
{
    _currentUser = currentUser;
}

IoC容器看到HomeController接受一个CurrentUser对象,CurrentUser构造函数接受一个I​​Identity。它将自动解决依赖关系,并中提琴!您的控制器可以知道当前登录用户是谁。对于我来说,使用FormsAuthentication似乎工作得很好。您可能能够将此示例适用于Windows身份验证。

原文地址:https://www.jb51.cc/aspnet/254630.html

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

相关推荐