本文将为您提供关于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重定向到父页面)
- 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重定向到父页面)
解决方法
但是如果你想在某些服务器端条件下重定向父框架,你可以从服务器调用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失效,无法重定向
今天在写项目的时候,想加一个切换用户,需要清除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
context.Response.StatusCode = 301; context.Response.Redirect(newUrl,true); context.Response.End();
我可以在fiddler看到它使用302而不是301.我应该在重定向调用后设置状态?
解决方法
asp.net – FormsAuthentication.RedirectFromLoginPage与Response.Redirect
虽然我已经回答了第一个问题,但我承认它只是“共同编程”.如果你看到,上述两个问题的答案相互矛盾,但仍然适用于各自的用户.
我想知道这之间究竟有什么区别
FormsAuthentication.SetAuthCookie(USER_NAME,true); Response.Redirect("copyPastPage.aspx");
而这个FormsAuthentication.RedirectFromLoginPage(mainSignUp.UserName,true);
在使用方面,我们可以看到Response.Redirect可以允许重定向到任何URL的逻辑差异,因为RedirectFromLoginPage只会重定向到referrer.但那是用法差异.
他们的执行方式是否存在根本分歧?如果没有,任何想法为什么一个人有时会工作,为什么有时呢?在他们每个人的引擎盖下究竟发生了什么?
我有点谷歌,但无法得到任何具体的答案.
解决方法
> 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
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的相关知识,请在本站进行查询。
本文标签: