response.sendRedirect()實現重定向(頁面跳轉)
在某些情況下,針對客戶端的請求,一個 Servlet 類可能無法完成全部工作。這時,可以使用請求重定向完成這一工作。
請求重定向指 Web 服務器接收到客戶端的請求後,可能由於某些條件的限制,不能訪問當前請求 URL 所指向的 Web 資源,而是指定瞭一個新的資源路徑,讓客戶端重新發送請求。
為瞭實現請求重定向,HttpServletResponse 接口定義瞭一個 sendRedirect() 方法,該方法用於生成 302 響應碼和 Location 響應頭,從而通知客戶端重新訪問 Location 響應頭中指定的 URL,sendRedirect() 方法的完整語法如下所示:
public void sendRedirect(java.lang.String location) throws java.io.IOException
在上述方法代碼中,參數 location 可以使用相對 URL,Web 服務器會自動將相對 URL 翻譯成絕對 URL,再生成 Location 頭字段。
sendRedirect() 方法的工作原理如圖 1 所示。
圖 1 sendRedirect()方法的工作原理
在圖 1 中,當客戶端訪問 Servlet1 時,由於在 Servlet1 中調用瞭 sendRedirect() 方法將請求重定向到 Servlet2,因此,瀏覽器收到 Servlet1 的響應消息後,立刻向 Servlet2 發送請求,Servlet2 對請求處理完畢後,再將響應消息回送給客戶端瀏覽器並顯示。
下面通過一個用戶登錄的案例分步驟講解 sendRedirect() 方法的使用。
1)創建頁面文件
在 servletDemo02 項目的 WebContent 目錄下創建一個用戶登錄的頁面 login.html 和登錄成功的頁面 welcome.html,編輯後如下所示。
① login.html文件
<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <title>用戶登錄</title> </head> <body> <!-- 把表單內容提交到 servletDemo02 工程下的 LoginServlet --> <form action="/servletDemo02/LoginServlet" method="POST"> 用戶名:<input type="text" name="username"><br/> 密 碼:<input type="password" name="password"/><br/> <br/> <input type="submit" value="登錄"/> </form> </body> </html>
② welcome.html文件
<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <title>歡迎頁面</title> </head> <body> 歡迎你,登陸成功! </body> </html>
2)創建 Servlet
在 servletDemo02 項目的 com.mengma.response 包中創建一個名為 LoginServlet 的 Servlet 類,用於處理用戶登錄請求,如下所示。
package com.mengma.servlet; import java.io.IOException; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class LoginServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException { response.setContentType("text/html;charset=utf-8"); // 用 HttpServletRequest 對象的 getParameter() 方法獲取用戶名和密碼 String username = request.getParameter("username"); String password = request.getParameter("password"); // 假設用戶名和密碼分別為 admin 和 123456 if ("admin".equals(username) && ("123456").equals(password)) { // 如果用戶名和密碼正確,重定向到 welcome.html response.sendRedirect("/servletDemo02/welcome.html"); } else { // 如果用戶名和密碼錯誤,重定向到 login.html response.sendRedirect("/servletDemo02/login.html"); } } public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException { doGet(request, response); } }
在上述代碼中,首先通過 getParameter() 方法分別獲取用戶名和密碼,然後判斷表單中輸入的用戶名和密碼是否為指定的“admin”和“123456”,如果是,則將請求重定向到 welcome.html 頁面,否則重定向到 login.html 頁面。
3)運行項目並查看結果
啟動 Tomcat 服務器,在瀏覽器的地址欄中輸入地址 http://localhost:8080/servletDemo02/login.html 訪問 login.html,瀏覽器的顯示結果如圖 2 所示。
圖 2 運行結果
在圖 2 所示的界面中填寫用戶名“admin”和密碼“123456”,單擊【登錄】按鈕,瀏覽器的顯示結果如圖 3 所示。
圖 3 運行結果
從圖 3 中可以看出,當用戶名和密碼輸入正確後,瀏覽器跳轉到瞭 welcome.html 頁面。但是,如果用戶名或者密碼輸入錯誤,則會跳轉到圖 2 所示的登錄頁面。
到此這篇關於response.sendRedirect()實現重定向(頁面跳轉)的文章就介紹到這瞭,更多相關response.sendRedirec 重定向內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- jsp+servlet實現簡單登錄頁面功能(附demo)
- Servlet簡單實現登錄功能
- Java 使用Filter實現用戶自動登陸
- JavaWeb中請求轉發和請求重定向的區別以及使用
- 解決Javaweb 提交表單到servlet時出現空白頁面,但網站不報錯問題