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/>
密&nbsp;&nbsp;&nbsp;碼:<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!

推薦閱讀: