servlet請求轉發(fā)與重定向的區(qū)別:
request.setAttribute("test","hello");
request.getRequestDispacther("/test.jsp").forword(request,response);
response.sendRedirect("test.jsp");
一、顯示結果:
1、當用request.getRequestDispacther("/test.jsp").forword(request,response); 請求轉發(fā)后,結果頁面輸出:hello
2、當用response.sendRedirect("test.jsp");重定向后,結果頁面輸出:null
二、底層分析:
1、請求轉發(fā)(RequestDispatcher)的過程:
客戶首先發(fā)送一個請求到服務器端,服務器端發(fā)現(xiàn)匹配的servlet,并指定它去執(zhí)行,當這個servlet執(zhí)行完之后,它要調(diào)用getRequestDispacther()方法,把請求轉發(fā)給指定的test.jsp,整個流程都是在服務器端完成的,而且是在同一個請求里面完成的,因此servlet和jsp共享的是同一個request,在servlet里面放的所有東西,在jsp中都能取出來,因此,jsp能把結果getAttribute()出來,getAttribute()出來后執(zhí)行完把結果返回給客戶端。整個過程是一個請求,一個響應。
2、重定向(sendRedirect)的工作原理:
客戶發(fā)送一個請求到服務器,服務器匹配servlet,這都和請求轉發(fā)一樣,servlet處理完之后調(diào)用了sendRedirect()這個方法,這個方法是response的方法,所以,當這個servlet處理完之后,看到response.senRedirect()方法,立即向客戶端返回這個響應,響應行告訴客戶端你必須要再發(fā)送一個請求,去訪問test.jsp,緊接著客戶端受到這個請求后,立刻發(fā)出一個新的請求,去請求test.jsp,這里兩個請求互不干擾,相互獨立,在前面request里面setAttribute()的任何東西,在后面的request里面都獲得不了??梢?,在sendRedirect()里面是兩個請求,兩個響應。
三、表面分析:
1、當用RequestDispatcher請求轉發(fā)后,地址欄為http://localhost:8080/test/TestServlet
這真好應正了上面的分析,我們起初請求的就一個servlet,至于你服務器端怎么轉,流程怎么樣的,我客戶端根本就不知道,我發(fā)了請求后我就等
著響應,那你服務器那邊愿意怎么轉就怎么轉,我客戶端不關心也沒法知道,所以當服務器端轉發(fā)到jsp后,它把結果返回給客戶端,客戶端根本就
不知道你這個結果是我真正訪問的servlet產(chǎn)生的,還是由servlet轉發(fā)后下一個組件產(chǎn)生的。
2、當用sendRedirect重定向后,地址欄為http://localhost:8080/test/test.jsp
因為這個時候,客戶端已經(jīng)知道了他第二次請求的是test.jsp,服務器已經(jīng)告訴客戶端要去訪問test.jsp了,所以地址欄里會顯示想要訪問的結果。