您好,登錄后才能下訂單哦!
這篇“怎么使用response.sendRedirect()實現重定向”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“怎么使用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()實現重定向”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。