首先我們要明白用response.sendRedirect做轉向的原理,它其實是向瀏覽器發送一個特殊的Header, " /> 久久免费视频9,99re6在线,国产精品免费一区二区三区四区

中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

jsp response.sendRedirect不跳轉的原因分析及解決

最近做項目時遇到一個問題,明明加了response.sendRedirect() ,系統也執行了,但是它就是不跳轉;最后在網上找到原因如下:

首先我們要明白用response.sendRedirect做轉向的原理,它其實是向瀏覽器發送一個特殊的Header,然后由瀏覽器來做轉向,轉到指定的頁面,所以用sendRedirect時,瀏覽器的地址欄上可以看到地址的變化。
用<jsp:forward page=""/>則不同,它是直接在server做的,瀏覽器并不知道,也不和瀏覽器打交道,這從瀏覽器的地址并不變化可以看出。

所以使用response.sendRedirect時就需要注意以下兩點:

1、在使用response.sendRedirect時,前面不能有HTML輸出。

這并不是絕對的,不能有HTML輸出其實是指不能有HTML被送到了瀏覽器。事實上現在的server都有cache機制,一般在8K(我是說JSP SERVER),這就意味著,除非你關閉了cache,或者你使用了out.flush()強制刷新,那么在使用sendRedirect之前,有少量的HTML輸出也是允許的。
如果報錯說,“一些信息已經被submitted”(原文忘了),那么,你就要注意看了,前面是不是有過多的HTML輸出了。

2、在response.sendRedirect之后,應該緊跟一句return;

我們已經知道response.sendRedirect是通過瀏覽器來做轉向的,所以只有在頁面處理完成后,才會有實際的動作。既然你已經要做轉向了,那么后的輸出還有什么意義呢?而且有可能會因為后面的輸出導致轉向失敗。

<%@ include file="/page/checkLogin.jsp" %>這個放在要驗證的頁面的第一句。

checkLogin.jsp 內容是通過看session 里面有沒登陸用戶的內容來判斷是否登錄, 如果沒有,那么跳轉到登陸頁面:
復制代碼 代碼如下:
<%@ page language="Java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%
if (session.getAttribute("userinfo") == null) {

response.sendRedirect(url);

return;
}
%>

jsp技術jsp response.sendRedirect不跳轉的原因分析及解決,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美精品久久久 | 国产精品久久国产精品 | 天天射影院| 一级a性色生活片久久毛片波多野 | 在线一区| 在线观看黄色大片 | 91在线视频国产 | 国产成人精品一区二区三区在线 | 狠狠的干 | 一级一级一级毛片 | 久久久久久亚洲精品 | 国产一级片av | 在线亚洲免费视频 | 99成人| 男女激情网站免费 | 麻豆av网站 | 91精品成人久久 | 99精品99| 欧美一级欧美一级在线播放 | 北条麻妃一区二区三区在线观看 | 特一级毛片 | 日本不卡一区 | 在线免费小视频 | 中文字幕一区二区三区精彩视频 | 成人欧美一区二区三区黑人孕妇 | 精品伦精品一区二区三区视频 | 亚洲精品一区二区三区四区高清 | 亚洲精品成人av | 伊人精品久久久久77777 | 国产成人精品久久二区二区91 | 99久久免费精品国产免费高清 | 欧美视频一区二区三区 | 欧美日韩中文在线 | 亚洲视频一区二区三区 | 韩日av在线 | 国产欧美日韩一区 | 亚洲一区二区三区四区五区午夜 | 亚洲一区二区三区久久久 | 日日夜夜精品视频 | 亚洲一区二区三区四区av | 国产精品人人做人人爽 |