ASP.NET FormsAuthentication跨站点登录时绝对地址返回的问题

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-01 20:40 点击:

 

在ASP.NET应用程序中,FormsAuthentication几乎是标配,但FormsAuthentication在设计时却没有考虑登录程序与当前程序不在同一个站点的场景。这个场景最基本的需求就是去另一个站点登录成功后返回要原地。可是FormsAuthentication在传递ReturnUrl时只支持相对路径,不支持绝对地址,也没有提供相应的扩展。

比如我们在admin.cnblogs.com站点的web.config中进行了如下的FormsAuthentication设置:

<authentication mode="Forms">

    <forms loginUrl="http://passport.cnblogs.com/login.aspx" timeout="2880" enableCrossAppRedirects="true"/>

</authentication>     

<authorization>

    <deny users="?" />

</authorization>

访问admin.cnblogs.cc/Home/Index,会被重定向至passport.cnblogs.com/login.aspx?ReturnUrl=%2fHome%2fIndex,这样登录后就回不来了。

那如何解决这个问题呢?

目前找到了三种方法:

方法一:在当前应用程序添加一个登录跳板页,web.config中的loginUrl指向该跳板,在跳板中获取ReturnUrl的绝对地址,再重定向至实际登录页面。

比如在ASP.NET MVC中,我们可以用一个Controller的Action作为跳板,代码如下:

public class LoginController : Controller

{

    public ActionResult Redirect()

    {

        var loginUrl = "http://passport.cnblogs.com/login.aspx";

        var returnUrl = "?ReturnUrl=http://" + Request.Url.Host +

            Request.QueryString["ReturnUrl"];

        return RedirectPermanent(loginUrl + returnUrl);

    }

}

然后将web.config中的loginUrl指向该Action。

该方法的缺点是要进行两次重定向。

方法二:在Global.asax的Application_PostAuthenticateRequest事件中将ReturnUrl设置为绝对地址,并重定向至登录页面。

代码如下(代码来自http://forums.asp.net/t/1358796.aspx):

protected void Application_PostAuthenticateRequest(object sender, EventArgs e)

{

    if (!UrlAuthorizationModule.CheckUrlAccessForPrincipal(

        Request.AppRelativeCurrentExecutionFilePath,

        Context.User, Request.RequestType))

    {

        Response.Redirect(String.Format("{0}?ReturnUrl={1}",

            FormsAuthentication.LoginUrl,

            Request.Url.AbsoluteUri));

    }

}

方法三:在Global.asax的Application_EndRequest事件中修改Response.RedirectLocation,将ReturnUrl的替换为绝对地址。

代码如下(代码来自David Findley's Blog):

protected void Application_EndRequest(object sender, EventArgs e)

{

    string redirectUrl = this.Response.RedirectLocation;

    if (!string.IsNullOrEmpty(redirectUrl))

    {

        this.Response.RedirectLocation = Regex.Replace(redirectUrl,

            "ReturnUrl=(?'url'.*)", delegate(Match m)

        {

            string url = HttpUtility.UrlDecode(m.Groups["url"].Value);

            Uri u = new Uri(this.Request.Url, url);

       &

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      用户名: 验证码:点击我更换图片
      最新评论 更多>>

      推荐热点

      • 浅析.NET下XML数据访问新机制
      • asp.net 面试+笔试题目第1/2页
      • C# 邮件地址是否合法的验证
      • asp.net 设置GridView的选中行的实现代码
      • C#高级编程:数据库连接[1]
      • 经典C++程序1
      • IIS 自动回收导致后台定时器失效的问题解决
      • ASP.NET&#160;GridView列表代码示例
      • Asp.net MVC源码分析--Action Filter的链式调用
      网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
      Copyright © 2008-2015 计算机技术学习交流网. 版权所有

      豫ICP备11007008号-1