每一個JSP頁面都會被Web容器編譯成一個Java類,供web容器調用,並且產生HTML頁面回饋給使用者。而了解其中的變異方法和規則,對我們學習JSP是非常有好處的,可以說學習好了這個編譯原理,就已經學習好了大部分的JSP知識,剩下的工作就只剩下熟記一些tablib和重複應用使自己更加熟練而已了
JSP會被編譯成.java放Tomcat/work/Catalina/localhost/***/org /apache/jsp/page
然後編譯成.class
jsp = java + html servlet = java + out.print(html)
1.客戶端發送請求給web容器
2.web容器將jsp先轉譯成servlet原始碼
3.web容器將servlet原始碼編譯成.class 檔案
4.web容器執行.class 檔案
5.web容器將結果回應給客戶端
JSP是一種腳本語言,包裝了Java Servlet系統的介面,簡化了Java和Servlet的使用難度,同時透過擴展JSP標籤(TAG)提供了網頁動態執行的能力。儘管如此,JSP仍沒有超出Java和Servlet的範圍,不僅JSP頁面上可以直接寫Java程式碼,而且JSP是先被翻譯成Servlet之後才實際運作的。 JSP在伺服器上執行,並將執行結果輸出到客戶端瀏覽器,我們可以說基本上與瀏覽器無關。它是與JavaScript不同的,JavaScript是在客戶端的腳本語言,在客戶端執行,與伺服器無關。
servlet可以被認為是伺服器端的applet。 servlet被Web伺服器載入執行,就如同applet被瀏覽器載入和執行一樣。 servlet從客戶端(透過Web伺服器)接收請求,執行某種作業,然後傳回結果。
使用servlet的基本流程如下:
·客戶端透過HTTP提出請求.
·Web伺服器接收該請求並將其發送給servlet。如果這個servlet尚未被加載,Web伺服器將把它加載到Java虛擬機器並且執行它。
·servlet將接收該HTTP請求並執行某種處理。
·servlet將向Web伺服器傳回應答。
·Web伺服器將從servlet收到的應答傳送給客戶端。
由於servlet是在伺服器上執行,通常與applet相關的安全性的問題並不需實作。要注意的是Web瀏覽器並不是直接和servlet通信,servlet是由Web伺服器載入和執行的。
而servlet是用Java寫的,所以它們一開始就是平台無關的。這樣,Java編寫一次就可以在任何平台運行(write once,run anywhere)的承諾就同樣可以在伺服器上實現了。
servlet還有一些CGI腳本所不具備的獨特優點:
servlet是持久的。 servlet只需Web伺服器載入一次,而且可以在不同請求之間保持服務(例如一次資料庫連線)。與之相反,CGI腳本是短暫的、瞬態的。每一次對CGI腳本的請求,都會使Web伺服器載入並執行該腳本。一旦這個CGI腳本運行結束,它就會被從記憶體中清除,然後將結果回到客戶端。 CGI腳本的每一個使用,都會造成程式初始化過程(例如連接資料庫)的重複執行。
servlet是與平台無關的。如前所述,servlet是用Java寫的,它自然也繼承了Java的平台無關性。
servlet是可擴充的。由於servlet是用Java來寫的,它就擁有了Java所能帶來的所有優點。 Java是健壯的、物件導向的程式語言,它很容易擴展以適應你的需求。 servlet自然也具備了這些特質。
servlet是安全的。從外界呼叫一個servlet的惟一方法就是透過Web伺服器。這提供了高水準的安全性保障,尤其是在你的Web伺服器有防火牆保護的時候。
以上是jsp編譯產生什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!