跳到主要內容

JSP(2)_Servlet應用

  • Servlet

是利用JAVA語言來實現CGI的一種方式,通常實作方式就是implement或是繼承httpservlet類別,在eclips環境下必須先import開發網頁所需要的類別servlet-api.jar載入(位置:在Tomcat 目錄的lib 目錄中)。






  • HttpServlet類別

         HttpServlet為一個抽象類別,主要接收/回應web容器的資料,大概常用的方法有get和
         post兩種。

(1)doGet: 主要接收前端的get的傳送方法
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {

}

(2)doPost:主要接收前端網頁的Post的傳送方法

    protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {


    }


(3)service:主要接收前端網頁的get/Post的傳送方法


  protected void service(HttpServletRequest arg0, HttpServletResponse arg1)
    throws ServletException, IOException {
    // TODO Auto-generated method stub
    super.service(arg0, arg1);
    }





  • servlet生命週期


  下圖是說明當我們建立好servlet物件時,web容器如何處理從前端接收到請求到servlet引擎
   執行後歸還資源。我們會一一說明之;

(1)載入Servlet類別: 當用戶喚起servlet物件時,他會將物件載入到web container中,而這樣類
                              別通常會在WEB-INF/classes下面。

(2)建立servlet實例:web.xml中定義的所有servlets實例都會建立自己的實例,當有很多需求進
                            來時,也只有一個servlet實例去做處理。

(3)呼叫init() :會先將web.xml所定義參數初始化,
(4)呼叫doPost()/doGet()方法:根據前端的需求去做處理,當有多個請求時,web容器會分配不
                                            同的執行緒做處理。
(5)摧毀servlet:當資源不夠或是應用程式關閉,JVM會自動的將實例回收。

  • MVC


早期因為JSP語法容易和前端HTML混在一起使用,而造成開發與維護上的困難與除錯難度高,所以漸漸衍生出MVC的軟體設計模式出現。MVC全名為Model-View-Controller,也就是說把一個系統分為檢視(View)、模型(Model)和控制器(Controller)。 下圖中可以說明了使用者與MVC架構之間的關係,當使用者一開始連線到伺服器時,出現預設的畫面,然後會根據使用者的想法,控制器會去做出使用者可預期的動作,例如:今天A君要輸出年度預算報表時,控制器會根據"這個需求"指派給預算模型去做計算並得到結果,再由控制器將結果回覆給前端的檢視介面。

模型       :   主要是負責商業邏輯的運算,具有高內聚的特性,當我設計系統時,商業領域
                  區分為多個模組去做各自任務與運算。這種方式方便複製到下一個專案開發所
                  需。

檢視介面:  負責使用者顯示的介面的方式(網頁、excel、視窗或是console介面等等)。

控制器   :   將使用者的請求需要做顯示或是商務模型(商業處理),你可以想像就是利用
                  servlet去做控制,這種方式可以減少顯示與程式之間的耦合度程度。



























留言

這個網誌中的熱門文章

GSON基礎教學

GSON 前言 JSON是很常見的資料交換格式,在JAVA領域常用處理JSON的函式庫:GSON、FastXML和JSON-B,本章節會以GSON為主,學習目標如下 JSON格式說明 GSON 套件函式 GSON: 物件轉換JSON字串 GSON: JSON字串轉換物件 JSON 格式說明 JSON全名為JavaScript Object Notation,它是一種輕量級的資料交換格式,會大為流行的理由,主要是他比傳統用xml更輕巧且容易處理, JSON表達方式物件會用大括弧{},陣列則是用中括號[]。 用JSON字串來表達Employee的物件內容,由JSON字串可以知道物件name、age、sex和salary屬性。 JSON表示員工資料方式: {“name”:”Jack Bryant”, “age”:18, “sex”:”M”,”salary”:3500.00} JSON陣列表示方式: 跟我們使用JAVA的陣列方式類似,內容值可以是數字’、文字、布林、陣列、物件、null等等。 範例: 字串: [“紅”、”橙”、”黃”、”綠”、”青”、”藍”、”紫”} 布林: [true, true, false, false, true, true] GSON 套件函式 Gson為google所發布的函式庫,主要將物件與json字串之間的轉換時方便使用。當我們將JAVA物件轉換成JSON字串稱為 序列化 ,JSON字串轉換至JAVA物件稱為 反序列化 。 GSON: 物件轉換JSON字串 有了JSON基本概念後,我們進入本章重點,首先我們需要建立員工類別(Employee),定義如下 物件 屬性 員工類別 Employee name 名字 age 年紀 sex 性別 salary 薪水 /** * name:員工類別 */ public class Employee implements Serializable { //constructor public Employee(String name, double salary){ this.name = name; this.sala...

PHP與Python搭配

今天介紹如何利用php網頁呼叫目錄下的python程式工作或是資料交換,本人整理的方法有兩種 使用system()、exec()、shell_exec()呼叫程式 (1) string system ( string return_var ] ) 參考網址 官網解釋system()用來執行外部命令,返回為印出的結果,passthru()跟system()類似但是它不會返回結果。 範例1. 利用system執行ls指定並顯示在網頁上,無法使用變數保留ls的結果 檔案名稱: psystem.php $jsondata= system("ls -al", $result); 結果: (2) exec() : string exec ( string output [, int &$return_var ]] ) 參考網址 範例2. 利用exec執行python程式並可以回傳json格式給前端網頁做處理並顯示。我們ptopy.php就是可以看到callpy()為執行py的函式,它執行完pyEx01.py會將結果給$jsondata變數,做後面json解析。 檔案名稱: ptopy.php function callpy() { $jsondata= exec("/usr/bin/python pyEx01.py"); return $jsondata ; } $jsondata= callpy(); echo $jsondata ; echo " " ; $obj = json_decode($jsondata) ; echo "name:".$obj-> { 'name'} .',' ; echo "id:".$obj-> { 'id'} ; 檔案名稱: pyEx01.py import sys ...

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