2011年11月27日 星期日

Java MVC sample #2

很快地,一個禮拜又過去了,這次takeshi要介紹的是Sample Project#2
經過Sample Project#1使用標準JavaEE技術實作的MVC架構介紹後
這次的Sample Project#2使用的主要技術如下
視 專案需求/不同的Device 抽換/同時使用 不同的UI技術,就takeshi的理解,
要作到RIA(Rich Internet Application),目前的主要技術有兩種,一種是Ajax技術 ,另外一種是Plug-in based技術(以後takeshi再詳細討論吧...)

而這次主要是使用plug-in based中相當主流的Adobe Flex(之後takeshi也打算再介紹Spring-MVC)
  • UI MVC使用技術:PureMVC for FLEX3 2.0.4
由於雲端運算和Web2.0概念的流行,現今網站應用程式(Web AP) 的操作都越來越接近傳統的Rich GUI(也就是需要安裝在客戶端的應用程式),亦或是更為複雜,所以除了使用系統整體架構上的MVC之外,也在UI層中再使用一層MVC架構,來讓專屬於UI操作的邏輯可以切分清楚,並且達到程式碼重用等好處

PureMVC不但有Flex的版本,它還有其它平台的版本,例如Java、JS等
但說真的,takeshi認為Pure MVC的架構蠻不錯的,但學習曲線不低...
不過takeshi以後有機會,也會在其它平台上使用PureMVC啦(Learn once Write Anywhere :p)
這個framework就不用多說了 吧,這是takeshi最喜愛的frameworkㄛ!
說到ORM技術,一般都是聽到hibernate、JPA等名稱,但takeshi對myBatis可是情有獨鍾
嚴格來說,它是SQL mapping技術,而不是ORM技術,它目的很簡單,就是幫助使用者可以很簡單的使用SQL,可以省掉很多像使用JDBC要撰寫的繁瑣程式碼,如getConnection、prepareStatement、ResultSet.close等,好學、易用、輕量!


在takeshi參與專案的經驗,架構的設計通常都是Multitier Architecture,例如本文後續所附之架構圖,就分為Client、Presentation、Biz Logic、Data Integration和Resource等,在此框架內使用哪一種技術,就必須基於系統的運行環境、限制和開發團隊(主要是Architect)的經驗做判斷

一般來說,之前已建立的系統架構可以當作之後專案架構的template(例如Sample Project #1 & #2),稍作修改便可直接使用,所以每次基於不同專案所作的不同系統架構,都可以保存在版本控制系統內,讓架構設計之解決方案越來越豐富,加快開發團隊的效率(也歡迎你/妳拿takeshi整理的架構來用ㄛ ^^)

接下來又到了介紹如何使用Sample Project#2囉~
1. 下載Sample Project
Sample code在這裡,把下載之zip檔案解壓縮並匯入到Eclispe裡

2. Tomcat設定,請參考Sample Project#1

3. 資料庫設定和ER-Model設計,也請參照Sample Project#1

4. 執行和操作方式


5. 本專案使用到的技術和架構如下

6. 參考文件
由於此次Sample Project使用了不同的技術,所以特別註明參考網址,方便網友們參考
  • Adobe Flex
Getting Started
Reference
Flash Builder Download
  • PureMVC
documents
  • Adobe BlazeDS
Main Page 
  • Spring-Core
Java API docs
  •  Spring-Flex
Main Page
  • MyBatis
Main page for Java

takeshi當初在整這個專案時,也花了大約兩~三天的時間,過程中小問題不斷
所以網友們有問題可以提出來跟takeshi討論ㄛ~

2011年11月20日 星期日

Java MVC sample #1

前陣子因為公司長官的要求,現在負責訓練新進JavaEE工程師的training
目前大部分新進同仁都會被派駐在user site,提供資訊服務,如軟體開發、實作等
所以讓新進同仁能快速學習到實務上會遇到的情形是一大重點

因此takeshi寫了個簡單的sample project,期望此sample project能滿足以下目標
  • Trace code:在大多數情況,要先看懂前人寫的code,比自己會寫還重要
  • MVC Design:現今的資訊系統開發,大多有使用到MVC Pattern,但剛出社會的新鮮人可能還沒碰過
  • Requirement Change:在新人看懂sample project之後,takeshi會提出新功能需求,請新人依據此sample project之MVC架構,直接長出新功能並驗收
  • 熟悉工具:Eclipse IDE、WTP、Tomcat和Debugger(不是開玩笑的,takeshi還真遇到有不少人不會用debugger...)
  • Container的使用:本sample project #1有使用到Tomcat的安全性服務,takeshi在實務上也看到不少實作都是用自己開發的元件來作,但takeshi想提醒的是Java Container的功能遠遠比我們想像的還多...
  • 尋序漸進: sample project #1是簡單版本,尚未套用任何framework,主要是讓新人知道,使用JavaEE Web Spec.是如何實作出MVC架構的,之後還有#2(Flex版本,希望未來有空時,再加上其它的版本)
接下來是重頭戲啦~以下介紹如何使用Sample Project #1

1. 下載 Sample Code
1.1 sample code在這裡,SVN Borwser在這裡
1.2 接著把程式training01.zip解壓縮並匯入到Eclipse中

2. 設定Tomcat
2.1 Tomcat版本6.0.x,在這裡下載
2.2 因為本專案使用到Tomcat安全性服務,所以要另外下載設定檔在這裡
在ZIP檔案中有三個檔案
server.xml 要複製到 ${TOMCAT_HOME}\conf\
h2-1.2.121.jar 要複製到 ${TOMCAT_HOME}\lib\
keystore 要複製到 ${user.home} \
當然你也可以改成你要的路徑,也請一併更改server.xml的94行
<Connector SSLEnabled="true" clientAuth="false"
 keystoreFile="${user.home}/keystore" keystorePass="changeit"
 maxThreads="200" port="8443" 
 protocol="org.apache.coyote.http11.Http11Protocol" scheme="https"
 secure="true" sslProtocol="TLS"/>
2.3 如何使用SSL登入Tomcat在這裡,如何使用JDBC Realm在這裡
2.4 把Tomcat加入至Eclispe的WTP中,待會執行Sample Project時,Eclispe會把project佈署在Tomcat裡執行

3. 資料庫設定
假如是測試或學習的目的,takeshi很喜歡使用H2 DB,它非常輕量(一個JAR檔,h2-1.2.121.jar),且在embedded mode還可支援多個連線(不像Derby或其它DB)
3.1 運行H2 DB,把${sampleProject#1}\trainingWebAp02\docs\db\createData.sql檔案中的SQL Script丟到H2 DB執行
3.2 會長出以下Schema和相關測試資料


4. 終於可以執行專案了!
執行和操作方式粉簡單,如下影片所示

5. 在本專案主要使用到的技術和架構如下

 需要特別注意的是
  • MVC分別由 Biz/Data Integration Tier代表Model和Controller,Presentation代表View
  • Presentation只能使用JSP/EL,儘量不在View裡撰寫Java code(Scriptlet),如邏輯相當複雜,可考慮使用javax.servlet.jsp.tagext套件求解(SimpleTagSupport等類別)
  • 由Biz/Data Integration Tier來同時處理Request/Response/DAO等工作,之後的Sample會再切分

今天就先寫到這吧,之後takeshi會在把Sample Project #2給放上來~

2011年11月19日 星期六

為什麼寫blog呢?

為什麼寫blog呢?

無非是想跟有興趣的朋友多分享一下自己的喜好吧
每天上班等下班,吃飽等下一餐,這樣庸庸碌碌的日子好歹也過了超過十年了
takeshi想說應該有些積累,潛水員當久了應當該有些回饋了吧...

往後takeshi會不定期地在此網誌分享自己看到、聽到、想到的東東
有興趣的朋友就一起來討論唄~