跳到主要內容

JSP(3)細談JSP語法

細談JSP語法

  • JSP語法

         JSP語法屬於內嵌式在HTML中,但是它會轉成Servlet Class檔,但是編譯器如何知道
         區分哪些是HTML語法,哪些是JSP語法。答案就是利用不同的標記去做辨識,基本  
         上web容器只認識 <% %>標籤內的語法並做轉換。以下會一一介紹這些語法的規範與
         應用。

JSP常用的語法整理
標記 說明 符號
註解
(Comment)
說明程式用,編譯器不會載入其內容 <%--  註解 --%>
宣告
(Declaration)
宣告變數名稱或是方法 <%! 宣告 %>
指令
(Directive)
載入JSP網頁之前需要使用載入的環境或是檔案 <%@ 指令%>
標記
(Scriptlet)
程式語法<% 程式碼 %>
運算式標記
(Expression)
運算式支援變數運算 <%=運算式%>


  • 註解:
    <%-- 註解 --%>編譯器看到這種標記,它會自動過濾掉不做編譯的動作,也不會再使用者   
    端看到註解內容。


  • 宣告:
     一般在此宣告的方法會在整個類別層級,提供該整個類別去做使用

    EX: <%! final String strHello="Hello,JSP">


  • 指令

    <%@ 指令 屬性="值" %>
EX :
<%@ page contentType="text/html;charset=ISO-8859-1" import="java." %>
<%@ page language="java" buffer="none" isThreadSafe="yes"  errorPage="/error.jsp" %>

屬性 說明
language JSP主要還是已支援java語言為主
<% page language="java"  %>
extends 使JSP可以繼承父類別的屬性或是方法
import JSP頁面上載入所需要的jar檔,提供後面方法使用。
<%@ page import = "java.util.*" %>
session value="true|false"如果為true就是能夠使JSP讀取到implicit session物件,預設為true
buffer value="none|10kb"指定緩衝區的容量,
autoFlush value="true| false" ,如果為true緩衝區會自動的flush,
isThreadSafe value="true|false",
errorPage 當發生錯誤時,可以導向到另外一個頁面。
<%@ page errorPage="error/myerror.jsp" %>
isErrorPage value="true|false",當發生錯誤時,是否會導向到另外一個JSP頁面做處理。
contentType value="text/html;charSet(網頁的字元集)=ISO-8859-1"

(1) info
利用info可以記載JSP文件的相關訊息,例如作者、版本以及版權宣告等等。
Ex: <%@ page info = "The web page , Copyright 1982 by Kevi Flynn." %>

(2)contextType屬性
設定Http回應的內容MIME,常設定有"text/html"、"text/xml"、"text/plain"等等,
Ex: <%@ page contextType= "text/html; charset=ISO-8859-1 "  %>

(3)pageEncoding
<%@ page pageEncoding="ISO-8859-1" %>

(4) extends
JSP轉譯為Servlet,希望該頁面可以繼承某個功能可以利用extends,如果使用HTTP協定需要實作javax.servlet.jsp.HttpJspPage介面,或是改用其他協定需要實作javax.servlet.jsp.JspPages介面

<%@ page extends="com.taglib.wdjsp.MyJspPage" %>

(5)import屬性
載入模組等於java import的敘述
Ex: <%@ page improt="java.util.list " %>

(6) buffer
控制緩衝區使用,緩衝區是可以保留前一個網頁的內容,不會因為錯誤或是意外而消失,建議使用<jsp:forward>或是errorPage屬性指定錯誤頁面時,都不要關閉緩衝區
<%@ page buffer="12Kb" %>
關閉緩衝處理: <%@ page buffer="none" %>

(7) autoFlush
當緩衝區已滿時,使否要將內容傳送出去頁面,預設為true,表示為送出頁面並清空。
<%@ page autoFlush = "true" %>
(8)isThreadSafe
是否可以安全處理多個用戶的請求,當你設定為false表示該JSP網頁不會讓多個執行緒去做處理,何時設為true或是false,當你連結資料庫,該頁面只可以被單一執行緒所去使用,所以該JSP頁面不可以同時處理多個要求,應將isThreadSafeˊ為false,但是若該資料連結可以做Connection Pooling時,表示後面的連結可以自動等待前面的回收後去做連結資料庫,所以isThreadSafeˊ為ture
  • include
         include指令用在我們可以載入其他檔案或是網頁(html、JSP),它在轉譯(translation
         time)階段就會將檔案做載入的動作。

     <%@ include file="header.html" %>
     <%@ include file="header.jsp" %>
屬性說明
file可以參考檔案或是URL做為載入的動作。
語法: file="檔案路徑"
  • taglib
        taglib為標記函式庫(tag library),它可以讓網頁開發者可以自訂自己的標記,當然SUN
        提供很標準的標記程式庫(JSTL,Java Standard Tag Library)。標記語法如下
        <%@ taglib prefix="標記" uri="標記程式庫.tld"  tagdir="標記目錄位址" %>


  • 宣告變數
<%! private int x=0 , y=0; private ......%>


  • JSP生命週期
執行JSP頁面 -> JSP容器初始化或是回收物件呼叫jspInit() ->  執行頁面 -> 回收JSP頁面jspDestory()
 這裡需要知道jspInit()和jspDestory()方法,


補充: uri一制性辨識子用來載入標記程式庫,TLD為XML的格式,用來定義標記的的結構。

(4)標記
     可以嵌入一般的java語法。
        

(5)運算式標記
       運算式標記格式;<%=expression %>
       運算式標記常用於顯示變數的值或是執行

隱含物件

隱含物件就是每個JSP的頁面,在web容器初始化時就會建立這些物件,所以不需要自行宣告,就可以使用。

物件名稱 類別或是介面 說明
page javax.servlet.jsp.HttpJspPage 表示該物件將JSP頁面可以轉換為Servlet的執行個體
config javax.servlet.ServletConfig JSP頁面可以轉換為Servlet的執行個體,該物件得ServletConfig的物件
request javax.servlet.http.HttpServletRequest 用戶端的物件的請求
response javax.servlet.http.HttpServletResponse 表示伺服器端的回應
out javax.servlet.jsp.JspWrite 表示為輸出串流
session javax.servlet.jsp.HttpSession 表示為seesion物件
application javax.servlet.ServletContext 長存在Web應用程式中,可以給所有JSP共用
pageContext javax.servlet.jsp.PageContext JSP的共同關聯資料
exception javax.lang.Throwable 代表沒有被截取一長


(1)page 物件



































留言

這個網誌中的熱門文章

JavaBean 和POJO

前言 今天介紹JavaBean和POJO的不同,這兩個名詞在JAVA文章常常被拿來使用以及討論。在JDK1.1時候釋出才有的一個標準架構,很多時候常常被搞混,所以我們特別開闢一章來加以討論。POJO規範在企業級應用已經廣大的被使用的規範。 解釋 POJO : 全名為Plain-old-Java-object,只需要繼承Object就可以,沒有特定規定,只要建立的類別有setter/getter方法都可以稱為POJO JavaBean: JavaBean通常用來封裝多個物件成為單獨物件使用,規範比較嚴格,規則如下 規則 說明 1 需要實作序列(Serializable/Externalizable) 2 不能有參數的建構子( no-arg constructor) 3 需要有公用setter/getter 4 屬性必須要私人(private) 5 屬於特定POJO規則 比較 所有的JavaBean都為POJO,但是所有的POJO不一定為JavaBean 都可以當作重複元件 都必須序列化 特性都為可用性、易用性和持久化使用 - 應用 由圖我們可以知道POJO在應用程式中,主要用來存取資料庫資料達到持久化的目的,並提供給商業邏輯流程處理使用。這種POJO的架構提供程式人員開發時的可以很有規則將資料封裝並加以使用。 範例1. JavaBean(以員工為實例) JavaBean建立員工物件,可以發現Employee物件建構子沒有任何參數,屬性為私有化並setter/getter的命名方式。 //實作序列化 public class Employee implements java.io.Serializable{ private int id; private String name; //無參數建構子 public Employee(){} //以下實作setter/getter public void setId(int id){this.id=id;} public int getId(){return id;} public void setName(String ...

Python AI-手寫辨識

Python AI-手寫辨識 類神經網路-手寫辨識 手寫辨識 (1) 問題定義 將輸入手寫數字圖片,經由類神經網路訓練後,可以辨識手寫圖片得到一個正確的答案,例如讓電腦辨識上面圖片手寫數字0-9,都可以認得.在了解問題後,需要先知道輸入的資料格式,例如圖片為NxN的矩陣向量. 輸入:輸入的資料格式有很多種,例如數字圖片為矩陣向量 模型:NN 輸出:輸出的方式,神經網路輸出不一定跟輸入同值,手寫數字輸入為1,輸出有可能是1.1或是1.5等等,所以輸出必須經過轉換成真實世界的數字. (2)定義函式 輸出會有兩個問題: A.輸出利用one-hot encoding來表示,就是N個狀態會對應N的結果,例如:輸出結果為1,表示[0,1,0,0,0,0,0,0,0,0] B.輸出結果不能超過1,我們通常會利用 Softmax函数 來進行輸出的處理. (3) 準備訓練/測試資料 在這邊需要從輸入去定義那些要當作訓練與測試資料,我們手寫資料使用MNIST 資料庫來訓練使用,MNIST共有70,000筆手寫資料,60,000筆為訓練資料,10,000為測試資料. (4)建構類神經網路模型 開始建構我們的神經網路模型,首先決定好28x28的像素(這邊不用擔心如何將圖片轉成矩陣),模型使用SGD的方式進行學習,輸出是一個10為的陣列來表示. 輸入:手寫數字圖片(28x28=784) 模型:SGD 輸出:數字(one hard encoding) (5)學習 首先介紹SGD(Stochastic Gradient Descent) 的學習方式,因為蕾神經網路需要訓練很多次才會提高準確度,SGD最大的好處就是當每次重新學習的會將訓練資料打散,來防止機器學習將答案死背下來. (6)實作開發 下面程式碼有完整的說明,這邊就不多說明了,當開始執行程式時就會進行資料訓練. 由訓練結果最後acc=0.9447,表示準確率可以到達94%,我們再由實際測試可以看出該圖為7的圖示,由神經網路判斷為7,跟我們人類判斷相同,我們可以知道由訓練的結果可看得到不錯的準確度. 執行神經網路遇到不少問題,請參考下面連結,是筆者所整理的問題集,請多多指教 https://programdoubledragon.bl...

Python AI-問題集

Python AI-問題集 問題集 Jupyter Notebook執行ipywidgets會出現kernel死掉的錯誤發生(The kernel appears to have died) 解決方法 (1) 根據log檔來判斷問題: 例如:log訊息出現OMP: Error #15: Initializing libiomp5.dylib, but found libiomp5.dylib already initialized. (2) 根據問題關鍵字找出問題所在: 利用google查詢所遭遇到的問題,例如我把上面的問題上google查詢可以找到這篇的解法 https://blog.csdn.net/bingjianIT/article/details/86182096 (3)實作解法: 我實作下面解法後,就可以順利執行手寫辨識的程式. //在Python宣告時加入 import os os.environ["KMP_DUPLICATE_LIB_OK"]="TRUE" 參考 https://blog.csdn.net/bingjianIT/article/details/86182096