GVKun编程网logo

asp.net – iFrame中的Response.Redirect(),重定向父窗口(iframe重定向到父页面)

7

本文将为您提供关于asp.net–iFrame中的Response.Redirect(),重定向父窗口的详细介绍,我们还将为您解释iframe重定向到父页面的相关知识,同时,我们还将为您提供关于aja

本文将为您提供关于asp.net – iFrame中的Response.Redirect(),重定向父窗口的详细介绍,我们还将为您解释iframe重定向到父页面的相关知识,同时,我们还将为您提供关于ajax请求后台,response.sendRedirect失效,无法重定向、ASP.NET Response.Redirect使用302而不是301、asp.net – FormsAuthentication.RedirectFromLoginPage与Response.Redirect、asp.net – Page_Load中的Response.Redirect的实用信息。

本文目录一览:

asp.net – iFrame中的Response.Redirect(),重定向父窗口(iframe重定向到父页面)

asp.net – iFrame中的Response.Redirect(),重定向父窗口(iframe重定向到父页面)

我知道这是不可能的,但是想要从iFrame执行Response.Redirect以重定向父页面的最佳选择是什么?

解决方法

你不能使用ASP.NET来做到这一点.服务器端的ASP.NET可以重定向传入的请求,但无法知道父帧.

但是如果你想在某些服务器端条件下重定向父框架,你可以从服务器调用JavaScript,如下所示:

protected void Page_Load(object sender,EventArgs e) {
   ClientScriptManager.RegisterClientScriptBlock(this.GetType(),"RedirectScript","window.parent.location = 'http://yoursite.com'",true);
}

当然,您可以在客户端使用简单的JavaScript window.parent.location =’http://yoursite.com’.

ajax请求后台,response.sendRedirect失效,无法重定向

ajax请求后台,response.sendRedirect失效,无法重定向

今天在写项目的时候,想加一个切换用户,需要清除session并且跳转到登录页面,发起一个ajax请求后,执行完发现无法跳转。

原因在于: 
(从网上摘录) 
Ajax只是利用脚本访问对应url获取数据而已,不能做除了获取返回数据以外的其它动作了。所以浏览器端是不会发起重定向的。 
1)正常的http url请求,只有浏览器和服务器两个参与者。浏览器端发起一个http请求,服务器端处理后发起一个重定向,浏览器端从response中获取到重定向地址,发起另一个http url请求。也就是说,浏览器会按照response中的内容进行响应(如重定向),这是浏览器的功能决定的就得响应。 
2)Ajax请求,参与者就有三个即ajax、客户端、服务器,ajax处于客户端和服务器两者之间。过程是客户端发起一个ajax请求,服务器端处理后,如果发起一个重定向,然后ajax会怎么办呢?它只会获取刚才请求返回的数据,其他的任何动作一概不去做,ajax是这么做的(ajax功能就是这么设定的,ajax框架源代码也是这么写的)。 
也就是说,引入了ajax之后,ajax就插在浏览器和服务器之间了,服务器给浏览器的response被ajax拦截了,但是ajax本身却什么都不做,也不转达。

解决方法: 
1.后台做完清除session后,传一个值给前台判断,在前台进行页面的跳转。 
后台:

@RequestMapping("/clearSession.html")
    public void clearSession(HttpServletRequest request,HttpServletResponse response)throws Exception{
        HttpSession session = request.getSession();
        BaseUser user = (BaseUser) request.getSession().getAttribute(Constants.USER_INFO);
        if(user!=null){//防止执行清除session的方法时,session已经过期。
            session.invalidate();
        }

前台:

success: function(data){
                        window.location.replace("/Nidson-ssm/login.jsp");
                    },
                    error:function(data) {
                        alert("服务器出错");
                        window.location.replace("/Nidson-ssm/login.jsp");
                    },

2.后台拦截ajax请求。

后台:

//对于请求是ajax请求重定向问题的处理方法
        public void reDirect(HttpServletRequest request, HttpServletResponse response) throws IOException{
            //获取当前请求的路径
            String basePath = request.getScheme() + "://" + request.getServerName() + ":"  + request.getServerPort()+request.getContextPath();
            //如果request.getHeader("X-Requested-With") 返回的是"XMLHttpRequest"说明就是ajax请求,需要特殊处理
            if("XMLHttpRequest".equals(request.getHeader("X-Requested-With"))){
                //告诉ajax我是重定向
                response.setHeader("REDIRECT", "REDIRECT");
                //告诉ajax我重定向的路径
                response.setHeader("CONTENTPATH", basePath+"/login.html");
                response.setStatus(HttpServletResponse.SC_FORBIDDEN);
            }else{
                response.sendRedirect(basePath + "/login.html");
            }
        }

前台:

var jqxhr;
    //设置ajax请求完成后运行的函数,
    $.ajaxSetup({ 
        complete:function(){
            if("REDIRECT" == jqxhr.getResponseHeader("REDIRECT")){ //若HEADER中含有REDIRECT说明后端想重定向,
                var win = window;
                while(win != win.top){
                    win = win.top;
                }
                win.location.href = jqxhr.getResponseHeader("CONTENTPATH");//将后端重定向的地址取出来,使用win.location.href去实现重定向的要求
            }
        }
    });

 

ASP.NET Response.Redirect使用302而不是301

ASP.NET Response.Redirect使用302而不是301

使用以下代码
context.Response.StatusCode = 301;

context.Response.Redirect(newUrl,true);
context.Response.End();

我可以在fiddler看到它使用302而不是301.我应该在重定向调用后设置状态?

解决方法

如果你使用ASP.Net 4.0,你可以使用 Response.RedirectPermanent,它将使用301而不是302。

asp.net – FormsAuthentication.RedirectFromLoginPage与Response.Redirect

asp.net – FormsAuthentication.RedirectFromLoginPage与Response.Redirect

这是参考 Login user after signup和 FormsAuthentication.RedirectFromLoginPage reload page这里提出的问题.

虽然我已经回答了第一个问题,但我承认它只是“共同编程”.如果你看到,上述两个问题的答案相互矛盾,但仍然适用于各自的用户.

我想知道这之间究竟有什么区别

FormsAuthentication.SetAuthCookie(USER_NAME,true);

Response.Redirect("copyPastPage.aspx");

而这个FormsAuthentication.RedirectFromLoginPage(mainSignUp.UserName,true);

在使用方面,我们可以看到Response.Redirect可以允许重定向到任何URL的逻辑差异,因为RedirectFromLoginPage只会重定向到referrer.但那是用法差异.

他们的执行方式是否存在根本分歧?如果没有,任何想法为什么一个人有时会工作,为什么有时呢?在他们每个人的引擎盖下究竟发生了什么?

我有点谷歌,但无法得到任何具体的答案.

解决方法

如果你看一下RedirectFromLoginPage中的代码,它基本上是一样的

> SetAuthCookie
>从查询字符串中获取返回URL
>清除返回网址

这是一个片段:

HttpContext current = HttpContext.Current;
    string returnUrl = GetReturnUrl(true);
    if (CookiesSupported || IsPathWithinAppRoot(current,returnUrl))
    {
        SetAuthCookie(userName,createPersistentCookie,strCookiePath);
        returnUrl = RemoveQueryStringVariableFromUrl(returnUrl,FormsCookieName);
        if (!CookiesSupported)
        {
            int index = returnUrl.IndexOf("://",StringComparison.Ordinal);
            if (index > 0)
            {
                index = returnUrl.IndexOf('/',index + 3);
                if (index > 0)
                {
                    returnUrl = returnUrl.Substring(index);
                }
            }
        }

但它也检查了对cookie的支持.

asp.net – Page_Load中的Response.Redirect

asp.net – Page_Load中的Response.Redirect

我的Page_Load中有一个Response.Redirect:
Protected Sub Page_Load(ByVal sender As Object,ByVal e As System.EventArgs) Handles Me.Load
    ...Code
    Response.Redirect("http://www.mysite.com")
End Sub

在添加Response.Redirect之前,我有其他子例程和工作代码

添加Response.Redirect后,他们都不会处理他们的代码并自动执行Response.Redirect网站.

当没有Response.Redirect时,我的代码可以正常工作.

解决方法

使用
Response.Redirect("http://www.mysite.com",false)

第二个参数指示当前页面的执行是否应该终止.

如果您使用Response.Redirect(“http://www.mysite.com”),当前页面执行将终止

今天的关于asp.net – iFrame中的Response.Redirect(),重定向父窗口iframe重定向到父页面的分享已经结束,谢谢您的关注,如果想了解更多关于ajax请求后台,response.sendRedirect失效,无法重定向、ASP.NET Response.Redirect使用302而不是301、asp.net – FormsAuthentication.RedirectFromLoginPage与Response.Redirect、asp.net – Page_Load中的Response.Redirect的相关知识,请在本站进行查询。

本文标签: