Play Framework介紹1--主要概念
本文翻譯自Play官方文檔。原文見:http://www.playframework.org/documentation/1.1.1/main
Play Framework是一個(gè)Rails風(fēng)格的Full-stack Java Web框架。
MVC模型
Play應(yīng)用遵循Web架構(gòu)使用的MVC架構(gòu)模式。
它將應(yīng)用分離到不同的層中:表現(xiàn)層(Presentation)和模型層(Model)。表現(xiàn)層進(jìn)一步分為視圖(View)和控制器(Controller)。
- Model 是應(yīng)用所處理信息的領(lǐng)域表述(Domain-Specific Representation)。絕大多數(shù)應(yīng)用使用持久化機(jī)制如數(shù)據(jù)庫存儲(chǔ)數(shù)據(jù)。但是MVC并沒有特別提到數(shù)據(jù)訪問層,因?yàn)樗鼘儆谙聦樱赡P头庋b。
- View 將模型渲染成適合交互的表單,通常是用戶界面。一個(gè)模型可有多個(gè)不同目的視圖。Web應(yīng)用中,View通常以HTML,XML或JSON形式呈現(xiàn),也可能是二進(jìn)制的Chart。
- Controller處理事件(通常是用戶動(dòng)作),并對(duì)模型做相應(yīng)改變。Web應(yīng)用中,事件通常是HTTP請(qǐng)求:Controller監(jiān)聽HTTP請(qǐng)求,從其中提取數(shù)據(jù),如查詢字符串參數(shù),請(qǐng)求頭,然后改變下層模型對(duì)象。
Play將此三層分在app目錄下的不同package中。
app/controllers
一個(gè)Controller就是一個(gè)Java 類,它的靜態(tài)公共方法則是動(dòng)作(Action)。動(dòng)作是接收HTTP請(qǐng)求后的Java處理入口點(diǎn)。Controller類實(shí)際是面向過程的,非OO。Action從HTTP請(qǐng)求中提取數(shù)據(jù),讀或更新Model對(duì)象,然后返回一個(gè)包裝成HTTP響應(yīng)(HTTP Response)的結(jié)果。
app/models
Model是一組具有所有OO特性的Java類。包含數(shù)據(jù)結(jié)構(gòu)和應(yīng)用可使用的操作。(譯注:即充血模型)。支持通過JPA持久化。
app/views
應(yīng)用的視圖由Play的模板系統(tǒng)生成。Controller從Model獲取數(shù)據(jù),然后使用模板呈現(xiàn)它。此package包含HTML,XML等模板文件,用作動(dòng)態(tài)生成模型的表述(Representation)。
請(qǐng)求生命周期
Play是完全無狀態(tài)的(stateless),且僅面向請(qǐng)求-應(yīng)答(Request-Response)。所有請(qǐng)求遵循相同路徑:
- 框架收到一個(gè)HTTP請(qǐng)求
- Router匹配請(qǐng)求和Controller、Action,執(zhí)行動(dòng)作方法。
- 應(yīng)用代碼執(zhí)行
- 繪制模型,呈現(xiàn)視圖
- 動(dòng)作方法的結(jié)構(gòu)作為HTTP響應(yīng)返回。
應(yīng)用程序布局
app目錄
包含所有可執(zhí)行的工件:Java源代碼和視圖模板。其下有三個(gè)標(biāo)準(zhǔn)package,每個(gè)代表MVC的一層。你也能添加你自己的包,如示例的utils包。
View pacakge可以在分子packages:
- tags 存儲(chǔ)應(yīng)用的ta。如可重用的模板片段。
- 一個(gè)Controller一個(gè)view目錄,按慣例,每個(gè)Controller的相關(guān)模板存儲(chǔ)在自己的子目錄中。
.class文件在哪兒?
Play在運(yùn)行時(shí)編譯Java源代碼,并將編譯的類緩存在tmp\bytecode目錄下。Play應(yīng)用的可執(zhí)行工件時(shí).java源文件,不是已編譯的.class(譯注:包括jar文件)。
public目錄
存儲(chǔ)靜態(tài)的、由Web服務(wù)器直接處理的資源。分為三個(gè)子目錄:images,stylesheets和javascripts,分別放圖片,css和js。
conf目錄
包含應(yīng)用的所有配置文件。兩個(gè)必須文件為:
- application.conf: 應(yīng)用主配置文件,包含所有標(biāo)準(zhǔn)的配置選項(xiàng)。
- routes:url路由規(guī)則定義文件。
此目錄包含在Java ClassPath中。
lib目錄
存放應(yīng)用依賴的標(biāo)準(zhǔn)Java類庫。此目錄自動(dòng)添加到Java classpath中。
開發(fā)生命周期
使用Play開發(fā)時(shí)沒有編譯,打包和部署這些階段,代之兩個(gè)不同環(huán)境:用于開發(fā)階段的DEV模式和用戶部署階段的PROD模式。
Java源代碼在運(yùn)行時(shí)編譯和加載。如果Java源文件在應(yīng)用運(yùn)行時(shí)發(fā)生改變,代碼會(huì)重新編譯并熱加載(hot-swapped)到JVM中。模板文件也是如此。
關(guān)于DEV/PROD模式
通過application.mode配置屬性切換DEV或PROD。DEV模式下,Play會(huì)檢查并在必要時(shí)熱加載。PROD模式為產(chǎn)品做了優(yōu)化:Java源文件和模板僅編譯一次。
調(diào)試
開發(fā)模式下通過JDPA連接到8000端口遠(yuǎn)程調(diào)試。(譯注:原文此處很簡(jiǎn)略,實(shí)際上可遠(yuǎn)程調(diào)試,也可本地調(diào)試)
posted on 2011-04-18 21:15 chaos 閱讀(701) 評(píng)論(0) 編輯 收藏 所屬分類: Play Framework