因此,我很高興偶然發現Vineet Reynolds做的一個更復雜的例子。 它被稱為“ Java EE 6 Galleria ”,您可以從bitbucket下載源代碼。 Vineet是為Arquillian項目做出貢獻的軟件工程師。 更具體地說,他貢獻了一些錯誤修復程序,并處理了Arquillian Core的一些功能請求,以及Arquillian的GlassFish,WebLogic和Tomcat集成。 這是我第一次遇到他的名字的地方。 跟著Arquillian的家伙和他走近一點,直接把我帶到了這個例子。 非常感謝Vineet在我初次嘗試使其開始運行時所提供的幫助。 如果您喜歡在Twitter @VineetReynolds上關注他。
這里是有關它的背景的簡要說明,也是關于在不同設置下運行它的一系列說明,并向您介紹了一些其他細節。 這是基本介紹。
關于回廊
該項目的高級描述如下:Java EE 6-Galleria是一個演示應用程序,演示了使用域驅動設計的Java EE項目中JSF 2.0和JPA 2.0的使用。 它被編寫為Java EE 6中域驅動設計的樣板。應用程序的域模型不是貧乏的,它由JPA實體組成。 然后,在用作應用程序層的會話EJB中使用這些實體。 使用Mojarra和PrimeFaces在表示層中使用JSF facelets。 該項目旨在通過使用JUnit 4中編寫的單元測試和集成測試來實現全面覆蓋。EJB和域模型的單元測試和集成測試依賴于EJB 3.1容器API。 表示層的集成測試依賴于Arquillian項目及其Drone擴展(用于執行Selenium測試)。
使用Java EE 6的域驅動設計
在Java EE 6中,將DDD作為一種體系結構方法是可行的,這主要是由于EJB 3.x中所做的更改以及JPA的引入。 EJB 3.x和JPA規范中所做的改進使得可以在Java EE 6中使用DDD對域和應用程序層進行建模。 這里的基本思想是設計一個應用程序,以確保將持久性服務注入到應用程序層中,并用于在應用程序層建立的事務上下文內訪問/持久化實體。
域層
該應用程序現在包含四個域實體-用戶,組,相冊和照片,它們與邏輯數據模型中的JPA實體相同。

儲存庫層
在邏輯數據模型的頂部,您可以找到四個存儲庫-UserRepository,GroupRepository,AlbumRepository和PhotoRepository。 每個用于四個域實體之一。 即使DDD要求您僅具有聚合根目錄的存儲庫,而不是所有域實體的存儲庫,其設計方式仍允許應用程序層訪問“相冊”和“照片”域實體,而不必通過UserRepository導航“相冊”和“照片”。 存儲庫是具有無接口視圖的無狀態會話Bean,并使用Adam Bien發布的通用CRUD服務模式構建。
應用層
應用程序層公開表示層要使用的服務。 它還負責事務管理,同時還充當下一層的故障屏障。 應用程序層與域存儲庫和域對象進行協調,以實現公開服務的預期目標。 在某種程度上,該層等效于傳統應用程序中的服務層。 應用程序層通過UserService,GroupService,AlbumService和PhotoService接口公開其服務,并且還負責在協調域層中的對象之間的動作之前,從上述層驗證提供的域對象。 這是通過域對象上的JSR-303約束完成的。
看起來如何
這就是如果在最新的GlassFish 3.1.2上運行該示例時的樣子。 想自己設置嗎? 等待下一篇文章,或者自己嘗試一下;)

下面,我們將直接使用最新的GlassFish 3.1.2,Hibernate和Derby來設置示例。
制備
讓自己有一些配置的心情。 Grep最新的NetBeans 7.1 (Java EE版本已經包含所需的GlassFish 3.1.2 )并進行安裝。 我還假設您在某個地方有一個不錯的Java SDK 7 (也可以完成6個工作)。 根據開發策略,您還需要Mercurial Client和Maven。 至少Maven也包含在NetBeans中,所以…我的意思是…為什么使您的生活變得比現在更艱難? ;)
環境環境
關于環境的更多一些話。 此示例是為支持不同的環境而設置的。 從簡單的“開發”環境開始,您還需要配置“測試”以及最后但并非最不重要的“生產”環境。 所有不同的環境都由Maven配置文件處理,因此您可能必須在接下來的幾分鐘內進行一些配置。
創建數據庫實例
首先要做的就是確定將所有東西放在哪里。 這些示例使用了開箱即用的derby,因此您應該安裝Java DB(JDK的一部分)或使用預先配置了NetBeans的GlassFish derby實例。 讓我們在這里變得更加困難,并假設我們使用JDK隨附的Java DB安裝。 繼續,打開CMD提示符并導航到%JAVA_HOME%文件夾,然后進一步向下db文件夾/ bin。 執行“ startNetWorkServer”腳本,并注意要啟動的derby實例。 現在打開另一個CMD提示符,同時導航到db / bin文件夾并執行“ ij”腳本。 這應該帶有提示“ ij>”。 現在輸入以下連接字符串:
connect 'jdbc:derby://localhost:1527/GALLERIATEST;create=true';
此命令將您連接到derby實例,并創建GALLERIATEST數據庫(如果尚不存在)。 Galleria示例使用了一個名為dbdeploy的方便的小工具作為數據庫更改管理工具。 它使您可以對物理數據庫模型進行增量更新,并在變更日志表中對其進行跟蹤。 (有關更多信息,請參閱本系列后面的內容)。 您必須創建更改日志表:
CREATE TABLE changelog (change_number DECIMAL(22,0) NOT NULL,complete_dt TIMESTAMP NOT NULL,applied_by VARCHAR(100) NOT NULL,description VARCHAR(500) NOT NULL
);ALTER TABLE changelog ADD CONSTRAINT Pkchangelog PRIMARY KEY (change_number);
您只需在connect語句中更改數據庫名稱,即可針對所需的任何其他實例(生產等)重做這些步驟。 并且不要忘記在每個實例中創建更改日志表。
如果您不喜歡這種方法。 啟動NetBeans,切換到“服務”選項卡,選擇“新建連接”,并添加一個新的Java DB網絡連接,其主機為:localhost,端口為:1527,數據庫為:GALLERIATEST; create = true。 將用戶名和密碼都設置為“ APP”,然后單擊“測試連接”。 選擇APP作為新數據庫的架構。 您完成了!

創建GlassFish域
我們正在從最新的GlassFish運行此程序。 現在要做的第一件事是創建一個新域。 導航到您的GlassFish安裝目錄并轉到glassfish3 / bin并執行以下命令:
asadmin create-domain --portbase 10000 --nopassword test-domain
這會為您創建一個新的測試域。 現在,導航到該域文件夾(“ glassfish3 / glassfish / domains / test-domain”)并打開config / domain.xml文件。
現在,我們將創建的derby數據庫作為連接池添加到您新創建的GlassFish域。 導航到<resources>元素,并在最后一個</ jdbc-connection-pool>元素下面添加以下連接池和jdbc-resource:
<jdbc-connection-pool driver-classname="" datasource-classname="org.apache.derby.jdbc.ClientDataSource40" res-type="javax.sql.DataSource" description="" name="GalleriaPool" ping="true"><property name="User" value="APP"></property><property name="DatabaseName" value="GALLERIATEST"></property><property name="RetrieveMessageText" value="true"></property><property name="Password" value="APP"></property><property name="ServerName" value="localhost"></property><property name="Ssl" value="off"></property><property name="SecurityMechanism" value="4"></property><property name="TraceFileAppend" value="false"></property><property name="TraceLevel" value="-1"></property><property name="PortNumber" value="1527"></property><property name="LoginTimeout" value="0"></property></jdbc-connection-pool><jdbc-resource pool-name="GalleriaPool" description="" jndi-name="jdbc/galleriaDS"></jdbc-resource>
現在,找到:<config name =“ server-config”>元素,并在其中尋找最后一個<resource-ref條目。 在此添加以下行:
<resource-ref ref="jdbc/galleriaDS"></resource-ref>
在我們準備啟動實例之前,要做的最后一件事。 我們需要為Galleria示例添加JDBC領域。 再次,找到<config name =“ server-config”>并在其中查找</ auth-realm>。 在此下面,放置以下內容:
<auth-realm classname="com.sun.enterprise.security.auth.realm.jdbc.JDBCRealm" name="GalleriaRealm"><property name="jaas-context" value="jdbcRealm"></property><property name="encoding" value="Hex"></property><property name="password-column" value="PASSWORD"></property><property name="datasource-jndi" value="jdbc/galleriaDS"></property><property name="group-table" value="USERS_GROUPS"></property><property name="charset" value="UTF-8"></property><property name="user-table" value="USERS"></property><property name="group-name-column" value="GROUPID"></property><property name="digest-algorithm" value="SHA-512"></property><property name="user-name-column" value="USERID"></property></auth-realm>
確保不要將新領域置于default-config下。 這是行不通的。 精細。 讓我們獲取資源:)
獲取源代碼并在NetBeans中打開它
Vineet在bitbucket.org上托管了Galleria示例。 因此,您必須去那里并訪問java-ee-6-galleria項目。 您可以通過三種方式將源帶到本地HDD。 通過hg命令行:

hg clone https://bitbucket.org/VineetReynolds/java-ee-6-galleria
或通過網站下載(右上方的“獲取資源”)或直接通過NetBeans。 對于第一個和第三個選項,您的操作系統需要一個Mercurial客戶端。 我正在Windows下使用TortoiseHg 。 在執行以下操作之前,您應該已經安裝了NetBeans并對其進行了配置 。 讓我們在這里嘗試最后一種選擇。 選擇“團隊>克隆其他”。 輸入存儲庫URL,并保留用戶/密碼為空。 單擊兩次“下一步”(我們不需要更改默認路徑;),然后選擇一個父目錄以將其放入其中。單擊“完成”,然后讓Mercurial客戶端執行工作。 完成后,要求您打開找到的項目。 該外觀應類似于右側的圖片。 如果遇到連接問題,請確保相應地更新代理設置。
如果嘗試構建項目,則會遇到麻煩。 它仍然缺少一些我們接下來要做的配置。
添加開發配置文件
接下來是在Galleria-ejb項目的Maven pom.xml中添加一些內容。 打開它并向下滾動到<profiles>部分。 您會找到兩個(聲納和生產)。 我們將通過在開發配置文件中添加以下幾行來添加開發配置文件(確保將GlassFish路徑調整為您的環境):
<profile>
<id>development</id>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
<properties>
<galleria.derby.testInstance.jdbcUrl>jdbc:derby://localhost:1527/GALLERIATEST</galleria.derby.testInstance.jdbcUrl>
<galleria.derby.testInstance.user>APP</galleria.derby.testInstance.user>
<galleria.derby.testInstance.password>APP</galleria.derby.testInstance.password>
<galleria.glassfish.testDomain.user>admin</galleria.glassfish.testDomain.user>
<galleria.glassfish.testDomain.passwordFile>D:/glassfish-3.1.2-b22/glassfish3/glassfish/domains/test-domain/config/local-password</galleria.glassfish.testDomain.passwordFile>
<galleria.glassfish.testDomain.glassfishDirectory>D:/glassfish-3.1.2-b22/glassfish3/glassfish/</galleria.glassfish.testDomain.glassfishDirectory>
<galleria.glassfish.testDomain.domainName>test-domain</galleria.glassfish.testDomain.domainName>
<galleria.glassfish.testDomain.adminPort>10048</galleria.glassfish.testDomain.adminPort>
<galleria.glassfish.testDomain.httpPort>10080</galleria.glassfish.testDomain.httpPort>
<galleria.glassfish.testDomain.httpsPort>10081</galleria.glassfish.testDomain.httpsPort>
</properties>
</profile>
好。 如您所見,這里定義了一些東西。 并且默認情況下激活配置文件。 而已。 目前。
測試ejb-Galleria項目
讓我們嘗試在ejb-Galleria項目中運行測試用例。 右鍵單擊它,然后發出“ clean and build”。跟隨控制臺輸出以查看實際發生的情況。 我們將在下一篇文章中對此做進一步調查。 今天,我們只是為了確保您以正確的方式設置所有設置。 它應該以以下內容結束:
Tests run: 49, Failures: 0, Errors: 0, Skipped: 0
BUILD SUCCESS
那是“綠色標準” :-)恭喜!
構建和部署項目
現在轉到NetBeans“工具>選項>其他> Maven”,然后選中以下框:“跳過測試以查找與測試沒有直接關系的任何構建執行”。 返回主窗口,右鍵單擊Galleria項目,然后進行清潔并在此處構建。
Reactor Summary:Galleria ................................. SUCCESS [0.431s]
galleria-ejb ............................. SUCCESS [5.302s]
galleria-jsf ............................. SUCCESS [4.486s]
Galleria EAR ............................. SUCCESS [1.308s]
------------------------------------------------------------
BUILD SUCCESS
------------------------------------------------------------
Total time: 11.842s
精細。 現在讓我們啟動GlassFish域。 切換到GlassFish安裝并找到glassfish3 / bin文件夾。 在此處打開命令行提示符并運行:
asadmin start-domain test-domain
您可以看到域正在啟動。 現在打開瀏覽器并導航到http:// localhost:10048 / 。 幾秒鐘后,這將向您顯示GlassFish服務器的管理控制臺。 現在您需要安裝Hibernate。 選擇“更新工具”(左下方),然后切換到“可用加載項”選項卡。 選擇“休眠”,然后單擊“安裝”(右上角)。 安裝服務器后,請停止服務器,然后使用上述命令重新啟動服務器。 再次打開管理控制臺,然后單擊“應用程序”。 單擊頂部的小“部署”按鈕,然后瀏覽至“ java-ee-6-galleria / galleria-ear / target / galleria-ear-0.0.1-SNAPSHOT.ear”。 單擊“確定”(右上角)。 幾秒鐘后您就完成了。 現在切換到http:// localhost:10080 / Galleria / ,您將看到歡迎屏幕。 恭喜你 您在GlassFish上設置了Galleria示例! 注冊,登錄并使用該應用程序!

該系列的下一部分將帶您深入了解應用程序的細節。 我將介紹測試和總體概念。 我們還將在以后的文章中同時更改JPA提供程序和數據庫。
是否想知道在最新的WebLogic 12c上進行安裝和運行需要什么? 繼續閱讀!
參考: Java EE 6示例– Galleria –第1部分和Java EE 6示例–在GlassFish 3.1.2上運行Galleria – JCG合作伙伴提供的 第2部分 ? Markus Eisele在Enterprise Software Development with Java博客上。
翻譯自: https://www.javacodegeeks.com/2012/03/java-ee-6-example-galleria.html