天天看點

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

近幾天,我的 ADSL 上不了網了。幾乎在家裡,隻能買碟看片。世界上有什麼大事,論壇中有多少 MM 灌水我都不知道。本來說,這帖要在周三時發出來。沒想到的是,昨天聯通公司才把網解決。10010的客服,我從回家開始打,一直打到夜裡12點,都沒人理。哎。。。

上次我們講到了 JSP 的指令操作。這次,我們要好好談談最後遺留下來的 JSP 動作。為什麼要單用一章來講。主要有兩個原因,一個是上次說的内容太多,怕接受不了。還有一點就是,JSP 動作要了解的内容不是一般的多,而是二般的多。是以要單給出一章節來好好談論談論。

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

如同上次所雲,JSP 動作用來控制 JSP 引擎的行為,執行一些标準常用的 JSP 頁面的動作。好像和 JSP 指令相近。指令用于通知,不直接顯示出來,而動作是要控制,并對頁面進行制作。

JSP動作包括以下幾點内容:

1、jsp:include:動态且可控的 include 加載,比那個指令 include 要靈活。

2、jsp:useBean:使用 JavaBean 控件。

3、jsp:setProperty:設定 JavaBean 屬性。

4、jsp:getProperty:輸出 JavaBean 屬性

5、jsp:param:用于傳遞參數,必須與其它支援這參數的标簽一起使用。

6、jsp:forward:引導請求進入新的頁面。

7、jsp:plugin:插入一個 applet 或 Bean。

一、jsp:include

1、說明:

jsp:include 動作在即将生成的頁面上動态地插入檔案,它在頁面運作時才将檔案插入,對被插入檔案進行處理。

2、格式:

<jsp:include page="檔案名" flush="true" />
           

<jsp:include page="檔案名" flush="true">
  <jsp:param name="參數名 1" value="參數值 1" />
  <jsp:param name="參數名 2" value="參數值 2" />
  ……
</jsp:include>
           

參數說明:

(1)page="檔案名"

制定需要插入檔案的 URL,該參數是一個相對路徑。

(2)flush="true"

隻能用true,沒得說。

(3)<jsp: param>

<jsp: param> 子句用于把值傳到到要插入檔案當中。

在相應的頁面中,隻要加入如下語句就可以将其值取出:

request.getParameter("參數名");
           

3、與 include 差別:

jsp:include 動作是動态的。當插入檔案時,JSP 引擎不把插入檔案和原 JSP 檔案合并成一個新檔案,而是在運作時把被插入檔案包含進來。插入者與被插入都雙方全都是獨立的。被插入檔案被改動了,會被判斷出來,并重新進行編譯。

include 指令是靜太的,把被插入檔案插入到目前位置後,再進行編譯,一旦有改動,無法得知。

4、舉個例子吧:

index.jsp

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
        <p><b>兩種遊戲機的感覺如何?</b></p>
        <jsp:include page="head.jsp" flush="true">
            <jsp:param name="chanshu1" value="PS3" />
            <jsp:param name="chanshu2" value="PSVita" />
        </jsp:include>
    </body>
</html>
           

head.jsp

<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
        <%
            String game1 = request.getParameter("chanshu1");
            String game2 = request.getParameter("chanshu2");
        %>
        <p><%=game1%>很貴!</p>
        <p><%=game2%>更貴!</p>
    </body>
</html>
           

運作一下看看結果:

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

二、jsp:forward 動作

1、說明:

jsp:forward 動作停止目前頁面的執行,轉向别一個頁面。在執行中,JSP引擎将不再處理目前頁面剩餘的内容,并把緩存區清空(等于這一頁白折騰了

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

)。好處在于,客戶看到的是原始的頁面位址,而實際顯示得卻是别一個頁面的内容。有于利隐藏展示頁面的位址,來得瑟一下。

2、格式:

<jsp:forward page="檔案名" />
           

<jsp:forward page="檔案名">
  <jsp:param name="參數名1" value="參數值 1" />
  <jsp:param name="參數名2" value="參數值 2" />
  ……
</jsp:forward>
           

參數說明:

(1)page="檔案名"

指明要定向跳轉的檔案或URL。

(2)jsp:param

同 jsp:include 動作中的 jsp:param 動作。就是傳值。接收方法如上。

3、舉個例子:

我們把 jsp:include 例子中 index.jsp 頁面裡的 include 改成 forward 看看結果,head.jsp 不用改,代碼如下:

index.jsp

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
        <p><b>兩種遊戲機的感覺如何?</b></p>
        <jsp:forward page="head.jsp">
            <jsp:param name="chanshu1" value="PS3" />
            <jsp:param name="chanshu2" value="PSVita" />
        </jsp:forward>
    </body>
</html>
           

head.jsp

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
        <%
            String game1 = request.getParameter("chanshu1");
            String game2 = request.getParameter("chanshu2");
        %>
        <p><%=game1%>很貴!</p>
        <p><%=game2%>更貴!</p>
    </body>
</html>
           

結果是:

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

index.jsp中的“兩種遊戲機的感覺如何?”沒有了。隻有 head.jsp 中的資訊了。

三、jsp:plugin 動作

1、說明:

jsp:plugin 動作的功能是将伺服器端的 Java 小應用程式(Applet)或 JavaBean 元件下載下傳到浏覽器端去執行,相當于在用戶端浏覽器插入 Java 插件。

jsp:plugin 動作将會動态生成 <object> 或 <embed> 元素标記,以使浏覽器的 Java 插件運作 Applet。同時,他也會指定對象是 applet,或者 Java Bean。也有可能是 Java Class 位元組碼檔案(.class),更有甚者是要下載下傳的 Java 插件。

2、格式:

<jsp:plugin
  type="bean|applet"
  code="儲存類的檔案名"
  codebase="類路徑"
  [name="對象名"]
  [archive="相關檔案路徑"]
  [align="bottom | top | middle | left | right"]
  [height="displayPixels"]
  [width="displayPixels"]
  [hspace="leftRightPixels"]
  [vspace="topBottomPixels"]
  [jreversion="Java環境版本"]
  [nspluginurl="供 NC 使用的 plugin 加域位置"]
  [iepluginurl="供 IE 使用的 plugin 加載位置"]
  <jsp:params>
    <jsp:param name="參數名 1" value="參數值 1">
    <jsp:param name="參數名 2" value="參數值 2">
  </jsp:params>
  [<jsp:fallback>錯誤資訊</jsp:fallback>]
</jsp:plugin>
           

參數說明:

(1)type="bean | applet"

指定插件對象的類型是 Bean 還是 Applet(二選一,請作答)。

(2)code="儲存類的檔案名"

要執行的 Java Class 位元組碼檔案(*.class)的名字。這個檔案必須儲存在由下面要介紹的 codebase 屬性所指定的目錄當中。

(3)codebase="類路徑"

這是指定 Java Class 位元組碼檔案(*.class)檔案的位置。沒有寫的話,就預設為目前 JSP 頁面的路徑。

(4)name="對象名"

bean 或 applet 執行個體的名字

(5)archive="相關檔案路徑"

預裝一些需要使用的 Java Class 位元組碼檔案(*.class)檔案,各檔案用“,”号分開,用于提高 applet 的性能。

(6)Align="bottom | top | middle | left | right"

指定顯示的對像和 applet 的位置。

(7)height="displayPixels" width="displayPixels"

好了解,展示的長寬的尺寸。

(8)hspace="leftRightPixels" vspace="topBottomPixels"

從英文字母的翻譯可以看出,一個設定水準間距,一個設定垂直間距。

(9)jreversion="Java環境版本"

Applet 或者 Java Bean 他們所運作的 Java Runtime Environment (JRE)的版本。預設版本是1.1。

(10)nspluginurl="供 NC 使用的 plugin 加域位置"

這個是來指定 Netscape Navigator 使用者所需要的 JRE 的下載下傳位址,是一個URL位址。

(11)iepluginurl="供 IE 使用的 plugin 加載位置"

這個如上,不同的是,這裡指得浏覽器是 IE。

(12)jsp:params 動作

和 jsp:include 或 jsp:forward 動作中的 jsp:params 動作一樣,就是傳個值。

(13)<jsp:fallback>錯誤資訊</jsp:fallback>

說白了,就是給自己一個後路。如果出錯了如何解決。

東西多,用得少。到時候要用到其它屬性的話,可以回來查一下清單。

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

3、舉個例子

我們首先找了一個 Java applet 小應用程式放到與 index.jsp 同級的目錄下(Clock.class)。

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

之後修改 index.jsp 中的代碼為:

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
        <p><b>兩種遊戲機的感覺如何?</b></p>
        <jsp:plugin type="applet" code="Clock.class" width="900" height="600">
            <jsp:fallback>為什麼會這樣?</jsp:fallback>
        </jsp:plugin>
    </body>
</html>
           

之後,運作網站,檢視結果:

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

感覺有點像 HTML 中的 <applet>。但是,它比 HTML 的 <applet> 更強大,更靈活。很多做過 JSP 開發的人都知道,Java Bean,在早期經典的 Java MVC 項目中作為 資料及業務邏輯操作。是以,強大的不是一輕半點。下面是在用戶端的代碼樣子:

<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
        <p><b>兩種遊戲機的感覺如何?</b></p>
        <OBJECT classid="clsid:8AD9C840-044E-11D1-B3E9-00805F499D93" width="900" height="600" codebase="http://java.sun.com/products/plugin/1.2.2/jinstall-1_2_2-win.cab#Version=1,2,2,0">
<PARAM name="java_code" value="Clock.class">
<PARAM name="type" value="application/x-java-applet;">
<COMMENT>
<EMBED type="application/x-java-applet;" width="900" height="600" pluginspage="http://java.sun.com/products/plugin/" java_code="Clock.class"/>
<NOEMBED>
為什麼會這樣?
</NOEMBED>
</COMMENT>
</OBJECT>

    </body>
</html>
           

四、jsp:useBean 動作

1、說明

終于談到 Bean了。 Java Bean 是一種可以重複使用的程式元件,他本身就是 Java 的類,是以要用 Java 來編寫。而 jsp:Bean 動作就是來調用這個程式元件的。其實感覺有點像上例一樣,隻不過,上例的 Java Applet 小應用程式隻是完成一種用戶端的顯示效果,而 Bean 是要作為伺服器上進行功能處理,對于我們是不可見的。

雖然我們以後才會接觸到 Java Bean,但是我們現在可以先說明一下它是什麼玩意兒。Java Bean 将網站的表示層(顯示給客戶看的頁面,用JSP來編寫。)與業務邏輯層公開,把業務及資料的處理交給 Bean 來完成。最後,再由JSP來調用 Bean 提供的結果,并顯示給客戶。這樣,降低了程式的複雜性,有利于日後的維護及再開發。

如果還不明白,我換一種少兒不宜且重口味的方式來說吧。JSP 就是我們看見的健康的美女,而 Bean 就是美女體内的動作的器官。一個美女的健康與否,是要看體内運作的結果所展現的。體内運作的好,是 Bean 在動作;外表的美是調用 Bean 動作的結果……大家明不明白,我反正是明白了。。。

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

無所謂,以後再要見到的。。。

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

2、格式

<jsp:useBean id="beanInstanceName" class="package.class" scope="page | request | session | application" /></jsp:useBean>
           

如果帶參數則:

<jsp:useBean id="beanInstanceName" class="package.class" scope="page | request | session | application" />
  <jsp:setProperty name="bean的名稱" property="屬性名稱" value="屬性值" />
  ...
  <jsp:setProperty name="bean的名稱" property="屬性名稱" value="屬性值" />
</jsp:useBean>
           

如果要得到 bean 傳回來的屬性值則:

<jsp:getProperty name="bean 名稱" property="屬性名稱" />
           

3、舉個例子

因為,這次的例子我們要編寫一下 Java 的開發環境。是以,我們需要對系統環境進行一下修改。

修改如下:

(1)、右擊“我的電腦”,選擇“屬性”,打開屬性視窗。

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

(2)、在打開的“屬性”視窗中選擇“進階系統設定”

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

(3)、之後在“系統屬性”面闆中點選“進階”标簽,并選擇“環境變量”

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】
不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

(4)在打開的“環境變量”中對“系統變量”進行設定:

1) 選擇變量“Path”,并單擊“編輯”按鈕。在其變量值中,加入 “Java 路徑\bin”,如“;L:\Program Files\Java\jdk1.6.0_23\bin;”,然後點選确定按鈕。

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

2)用上面的方面,點選來對環境變量“CLASSPATH”進行設定(如果沒有“CLASSPATH”,那就點選“建立”按鈕,直接建一個)。

之後,設定變量值為 .; Java 路徑\jre\lib\rt.jar; 如“.;L:\Program Files\Java\jdk1.6.0_23\jre\lib\rt.jar;”:

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

3)一直點選确定後退出。可能,你需要重新開機一下計算機(有的是,有的不是,最好大家都重新開機一下)。

好了,我們現在打開記事本,開始編寫 Java Bean。鍵入下面的 Java 代碼,并儲存為 Box.java:

package bean;

import java.io.*;

public class Box{
	int length, width, height;

	public Box(){
		length = 1;
		width = 1;
		height = 1;
	}

	public void setlength(int newlength){
		length = newlength;
	}

	public void setwidth(int newwidth){
		width = newwidth;
	}

	public void setheight(int newheight){
		height = newheight;
	}

	public int getlength(){
		return length;
	}

	public int getwidth(){
		return width;
	}

	public int getheight(){
		return height;
	}

	public int BoxVolume(){
		return length * width * height;
	}

	public double BoxArea(){
		return 2 * (length * width + width * height + length * height);
	}

}
           

好了,打開運作對話框,快捷鍵:Ctrl + R,之後輸入 cmd 回車。

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

之後在打開的字元指令行中,通過指令,進入到 Box.java 所儲存的目錄之下,并輸入 javac Box.java 進行編譯。

若是沒有錯誤,将會出現下面的情況:

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

在Box.java所在的目錄下會出現一個新的檔案“Box.class”。這就是我們編寫好,并編譯的 Java Bean 檔案。

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

好了,現在全齊了。之後,我們開始來寫 JSP 代碼了。打開 NetBeans 編輯器,将行成的 Box.class 檔案複制于 網站目錄下的 WEB-INF檔案夾的 classes 檔案夾内的 bean 檔案夾下。

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

現在成了。我們來改一下 index.jsp 檔案的代碼,代碼如下:

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
        <h3>正方體計算</h3>
        <form method="post" action="head.jsp">
            <p>正方體的長:<input type="text" name="BoxLength" style="width: 20px;" /></p>
            <p>正方體的寬:<input type="text" name="BoxWidth" style="width: 20px;" /></p>
            <p>正方體的高:<input type="text" name="BoxHeight" style="width: 20px;" /></p>
            <p>
                <input type="submit" value="計算" name="submit" />
                 
                <input type="reset" value="重置" name="reset" />
            </p>
        </form>
    </body>
</html>
           

head.jsp 代碼如下:

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@page import="bean.Box"%>
<jsp:useBean id="Box" class="bean.Box" scope="request"></jsp:useBean>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
        <%
            Box b = new Box();
            b.setlength(Integer.parseInt(request.getParameter("BoxLength")));
            b.setwidth(Integer.parseInt(request.getParameter("BoxWidth")));
            b.setwidth(Integer.parseInt(request.getParameter("BoxHeight")));
        %>
        <p>長方體的體積:<%=b.BoxVolume()%></p>
        <p>長方體的面積:<%=Box.BoxArea()%></p>
    </body>
</html>
           

運作一下,先在 index.jsp 中輸入資料:

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

之後點選計算按鈕顯示出結果:

不要急,我與你一起學習JSP(四)——JSP的基礎文法【二】

我們在編譯器當中,看到目錄下有很多東西。這些東西都對于伺服器開發很有用處。下次,我們花一天的時間來說明一下。今天就先到這裡了。