三层Web应用程序

时间:2008-12-27 17:07:30

标签: c# redirect routing layer

是否可以 - 最好的做法 - 使用第二层重定向用户?

例如:

public static void ForceLogin()
{
    HttpCookie cookie = HttpContext.Current.Request.Cookies[cookieName];

    if (cookie != null)
    {
        if (Regex.IsMatch(cookie.Value, "^[0-9]+\\.[a-f0-9]+$"))
        {
            using (EibxDataContext db = new EibxDataContext())
            {
                int count = db.Logins.Count(l => l.Password == cookie.Value);

                if (count == 1)
                {
                    return;
                }
            }
        }
    }

    HttpContext.Current.Response.Redirect("~/Login.aspx");
}

在最后一行,我使用业务/服务逻辑层将用户重定向到登录页面。

这应该在Presentation层中完成吗?

3 个答案:

答案 0 :(得分:8)

绝对不是。业务逻辑层应该做出决定,UI层应该进行重定向。业务层不应该对HttpContext有任何了解,也不应该直接读取cookie。将相关信息传递到业务层,以便业务层可以做出决策,并将决策传递给UI层,以便它可以处理由此产生的决策。

这就是原因......如果从Web服务使用业务层会怎么样?业务层如何在该实例中进行重定向?或者假设它与非Web客户端一起使用?重定向在该上下文中没有意义。如果您更改了UI图层,这不应该影响您的业务逻辑层,并且将重定向和cookie读取混合到业务层中将需要使用所提议的设计。

答案 1 :(得分:5)

这取决于您如何定义图层;例如,我的“业务逻辑”通常与我试图解决的问题有关,并且对UI没有任何了解。因此它无法进行重定向,因为它无法访问请求/响应。

就个人而言,我会在UI层执行此操作;处理诸如守门人和监护人之类的原始交互是UI层的Web应用工作的一部分。 IMO。例如,通过http模块,(根据定义)是UI级组件。

答案 2 :(得分:0)

我会说你在商业逻辑中这样做是对的。表示层不应该做出关于路由的决定。