servlet 轉發、包含(七)

来源:http://www.cnblogs.com/wwyx-xi/archive/2017/09/26/7599237.html
-Advertisement-
Play Games

1.什麼是servlet轉發? servlet將用戶的請求通過一組servlet來處理,每個servlet都有自己特定的職責,當該servlet完成自己的工作後將請求轉發到下一個servlet來處理,這種通過不同servelet相互轉發請求來完成對某個請求的處理過程就叫做servlet轉發。 2.什 ...


1.什麼是servlet轉發?

  servlet將用戶的請求通過一組servlet來處理,每個servlet都有自己特定的職責,當該servlet完成自己的工作後將請求轉發到下一個servlet來處理,這種通過不同servelet相互轉發請求來完成對某個請求的處理過程就叫做servlet轉發。

2.什麼是servlet包含?

  servlet包含就是源servlet將其他web組件(servlet,html,jsp),生成的結果包含到自己的結果中。

3.為什麼需要servlet轉發和包含?

  servlet對象是由Servlet容器創建,Servlet對象的Service()方法是由servlet容器調用,servlet之間是不允許相互調用(servlet API 2.1以前版本可以)。但是我們又需要通過多個servlet組件協調完成任務,同時方便代碼維護管理,提高開發效率。這樣就可以需要servlet轉發和包含的技術支持。

4、轉發和包含的相同點

  (1)都是對同一個請求對象處理,源組件和目標組件共用同一個ServletRequest對象和ServletResponse對象。

  (2)目標組件都可以是servlet,jsp,html。

  (3)都依賴javax,servlet.RequestDispatcher 介面。

5.RequestDIspatcher 對象

  該介面表示請求分發器

  (1)獲取RequestDispatcher對象方法

    調用ServletContext的getRequestDispather(String path)方法獲得。

    調用ServletRequest的getRequestDispather(String path)方法獲得。

  (2)兩種方法的區別

    ServletContext調用方法的參數必須為絕對路徑,而ServletRequest調用方法參數可以是絕對路徑也可以是相對路徑。

6.請求轉發案例

CheckServlet 類用於處理用戶請求參數。
package com.learn;

import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * Created by Administrator on 2017/09/26.
 */
public class CheckServlet extends HttpServlet{

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        String userName = req.getParameter("name");
        String message = "";

        if(userName == null){
            message = "please input your name";
        } else {
            message = userName;
        }
        req.setAttribute("mess",message);
        RequestDispatcher requestDispatcher = getServletContext().getRequestDispatcher("/out");

        PrintWriter out = resp.getWriter();
        out.print("before forward ");
        System.out.println("before forward");

        requestDispatcher.forward(req,resp);

        out.print("after forward");
        System.out.println("after forward");

        out.close();
    }


}
OutServlet  用於輸出處理結果
package com.learn;

import org.json.HTTP;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * Created by Administrator on 2017/09/26.
 */
public class OutServlet extends HttpServlet {

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        String message = (String) req.getAttribute("mess");

        PrintWriter printWriter = resp.getWriter();
        printWriter.print(message);
        printWriter.close();

    }
}

註意:   1.在轉發之前不要提交響應結果。

    2.轉發過程中,源組件的響應結果不會返回,只會返回目標組件的響應結果。

 

web.xml配置

  <servlet>
        <servlet-name>check</servlet-name>
        <servlet-class>com.learn.CheckServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>check</servlet-name>
        <url-pattern>/check</url-pattern>
    </servlet-mapping>
    
    <servlet>
        <servlet-name>out</servlet-name>
        <servlet-class>com.learn.OutServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>out</servlet-name>
        <url-pattern>/out</url-pattern>
    </servlet-mapping>

 

7.包含(include)案例 

MainServlet  用於包含其他組件,並返迴響應結果
package com.learn;

import javax.servlet.RequestDispatcher;
import javax.servlet.Servlet;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * Created by Administrator on 2017/09/26.
 */
public class MainServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        resp.setContentType("text/html");

        PrintWriter out = resp.getWriter();
        out.println("<html><head><title>mainServlet</title></head>");
        out.println("<body>");

        ServletContext servletContext = getServletContext();

        RequestDispatcher headDisPatcher = servletContext.getRequestDispatcher("/header.html");
        RequestDispatcher greetDisPatcher = servletContext.getRequestDispatcher("/greet");
        RequestDispatcher footeDisPatcher = servletContext.getRequestDispatcher("/footer.html");

        headDisPatcher.include(req,resp);
        greetDisPatcher.include(req,resp);
        footeDisPatcher.include(req,resp);

        out.print("</body></html>");
        out.close();


    }
}

 

header.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>header</title>
</head>
<body>
<font size="6">Welcome to ab</font>
</body>
</html>
GreetServlet 
package com.learn;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * Created by Administrator on 2017/09/26.
 */
public class GreetServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        PrintWriter out = resp.getWriter();

        out.print("hi! "+req.getParameter("name")+", <p>");
        out.close();
    }
}

footer.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>footer</title>
</head>
<body>
<span>Thanks for stopping</span>
</body>
</html>

web.xm配置

 <servlet>
        <servlet-name>main</servlet-name>
        <servlet-class>com.learn.MainServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>main</servlet-name>
        <url-pattern>/main</url-pattern>
    </servlet-mapping>

    <servlet>
        <servlet-name>greet</servlet-name>
        <servlet-class>com.learn.GreetServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>greet</servlet-name>
        <url-pattern>/greet</url-pattern>
    </servlet-mapping>

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • jps:JVM Process StatusTool,顯示指定系統內所有的HotSpot虛擬機進程 jstat:JVM Statistics Monitoring Tool,用於手機HotSpot虛擬機各方面的運行數據 jinfo: Configuration Info for Java 顯示虛擬機 ...
  • 在瞭解了 "AQS獨占鎖模式" 以後,接下來再來看看共用鎖的實現原理。 原文地址:http://www.jianshu.com/p/1161d33fc1d0 搞清楚AQS獨占鎖的實現原理之後,再看共用鎖的實現原理就會輕鬆很多。兩種鎖模式之間很多通用的地方本文只會簡單說明一下,就不在贅述了,具體細節可 ...
  • 本章內容繞不開一個名詞:RTTI(Run-time Type Identification) 運行時期的類型識別 知乎上有人推斷作者是從C++中引入這個概念的,反正也無所謂,理解並能串聯本章知識才是最重要的 本章的內容其實都是為類型信息服務的,主要內容有 一.Class對象 問題: 1.Class對 ...
  • 1. #!/usr/bin/python 和#!/usr/bin/env python 含義 大部分python文件的頭部都會寫上 #!/usr/bin/python 或者 #!/usr/bin/env ,這個語句主要和運行模式有關, 如果我們用普通運行模式例如(linux) : python *. ...
  • 首先,先看個例子吧 上面的代碼,是典型的懶漢式單例模式,在單線程的情況下,完全是沒有問題的,但是在多線程的環境下,就很難保證對象的單例了。那應該如何去保證在多線程的環境下的單例呢?相信學過了,學過多線程的基本知識的都知道在可能會產生併發的地方,加上同步就好,即synchronized(同步方法或者同 ...
  • 模擬購物車程式,判斷用戶薪資是否是0 如果是0就需要輸入薪資,並記錄到文件內。 可以預先存個字典格式的字元串,然後去讀取文件的時候讀到的是字字元串然後再去用eval去轉換成字典。 當我們覆蓋寫到文件的時候就會發現首行會有空格,當我們再去讀取eval的時候就會報錯,那怎麼樣可以解決這個問題呢! ...
  • 參考教程:http://www.tensorfly.cn/tfdoc/tutorials/mnist_beginners.html 數據下載地址:http://wiki.jikexueyuan.com/project/tensorflow-zh/tutorials/mnist_download.ht ...
  • 今天我們來學習集合的第一大體系 List。 List 是一個介面,定義了一組元素是有序的、可重覆的集合。 List 繼承自 Collection,較之 Collection,List 還添加了以下操作方法 位置相關:List 的元素是有序的,因此有get(index)、set(index,objec ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...