這篇文章主要介紹了spring Roo怎么用,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
專注于為中小企業(yè)提供網(wǎng)站設(shè)計制作、做網(wǎng)站服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)惠陽免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
安裝
安裝命令行工具
Spring Roo是一套命令行工具,如果你使用的是Eclipse/STS,還可以使用Eclipse對應(yīng)的插件。
首先先來下載命令行工具。到下載頁面,選擇對應(yīng)版本下載。這里我選擇的是最新的2.0.0.RC1 ,畢竟我有更新強(qiáng)迫癥。下載完成之后解壓,會得到一個文件夾,其中bin目錄下就是Spring Roo的可執(zhí)行文件了。可以看到它有bat和sh兩種格式,可以在不同系統(tǒng)上運行。為了方便以后在終端窗口運行,我建議同時將這個文件夾添加到環(huán)境變量中。
安裝好之后,打開命令提示符或者其他終端窗口,輸入roo命令,就可以啟動Roo了。值得提一點,Roo會在命令提示符對應(yīng)的文件夾位置創(chuàng)建項目,所以如果需要在特定位置創(chuàng)建項目,先在命令提示符中切換到該文件夾,然后再啟動Roo。
安裝Eclipse插件
打開你的Eclipse/STS,然后遵循以下步驟:
點擊菜單欄 Help ? Install New Software
點擊 Available Software sites
點擊 Import 按鈕
找到 “$ROO_HOME/conf/sts-sites-bookmarks.xml” 并確定,這里$ROO_HOME是你安裝Roo的目錄
根據(jù)需要選擇對應(yīng)的版本
在過濾欄輸入roo
選中功能 Spring IDE Roo Support
然后一路確定并允許條款
最后重啟IDE即可
下面是官方文檔的圖,如果有疑問照著這張圖來就行了。
到這一步還沒完,插件是安裝好了,但是還沒有配置。其實要配置的也很簡單,告訴插件你的Roo工具安裝到哪里就行了。點擊 Window ? Preferences ? Spring ? Roo Support ,打開設(shè)置,然后照著官方文檔截圖設(shè)置好你的工具路徑即可。
這樣插件就設(shè)置完畢了。其實這個插件也沒啥作用,就是在Eclipse中開了一個窗口,能運行Roo命令,和直接在命令提示符中運行其實是一樣的。
使用Roo
運行Roo腳本
$ROO_HOME\samples文件夾下有三個示例項目腳本,使用Roo運行它們可以快速創(chuàng)建相應(yīng)的項目。如果沒有耐心,可以直接從這里開始。
比如說,我要運行clinic實例項目,就可以輸入以下命令:
roo> script --file clinic.roo
稍等片刻,程序就會創(chuàng)建完畢。
最后創(chuàng)建出的是一個基于Maven的Spring Boot程序。在IDEA下是這么一個樣子??梢钥吹巾椖恐杏幸粋€名字叫l(wèi)og.roo的日志文件,它記錄了這個Roo腳本執(zhí)行的內(nèi)容。另外不知道為什么程序在IDEA下會有一點報錯,不過不影響編譯和運行。
這個PetClinic示例程序使用了Spring Security來保護(hù)頁面。我查閱了一下,Spring Boot下Spring Security默認(rèn)的用戶名是user,密碼則在程序啟動的時候隨機(jī)輸出到控制臺中。最后運行截圖如下,大家可以自己運行和測試一下這個程序。
腳本解釋
下面來解釋一下PetClinic這個程序的Roo腳本,讓我們來看看Roo是如何工作的。這里只做一下簡單解釋,如果需要詳細(xì)資料的話可以參考官方文檔的附錄,完整介紹了Roo的各種命令和參數(shù)以及用法。
首先是創(chuàng)建項目并指定頂級包名,這樣會創(chuàng)建一個基于Maven的Spring Boot項目。
project setup --topLevelPackage org.springframework.roo.petclinic
然后是指定JPA存儲類型,這里用的是Hibernate,數(shù)據(jù)庫是存儲在內(nèi)存的HSQLDB。當(dāng)然也可以使用其它數(shù)據(jù)庫,不過相應(yīng)地需要增加用戶名等其他參數(shù)。
jpa setup --provider HIBERNATE --database HYPERSONIC_IN_MEMORY
然后是幾個枚舉類,將會在實體類中用到,這里的~指代前面設(shè)置的頂級包名。
enum type --class ~.domain.reference.PetType enum constant --name DOG enum constant --name CAT enum constant --name BIRD enum type --class ~.domain.reference.Specialty enum constant --name CARDIOLOGY enum constant --name DENTISTRY enum constant --name NUTRITION
然后是項目中的幾個實體類。
entity jpa --class ~.domain.Pet --sequenceName PET_SEQ --entityFormatExpression "#{name} (#{type})" entity jpa --class ~.domain.Visit --sequenceName VISIT_SEQ --entityFormatMessage visit_format entity jpa --class ~.domain.AbstractPerson --abstract entity jpa --class ~.domain.Vet --extends ~.domain.AbstractPerson --entityFormatExpression "#{lastName} (#{specialty})" entity jpa --class ~.domain.Owner --extends ~.domain.AbstractPerson --entityFormatExpression "#{lastName} (#{city})"
之后的叫本詳細(xì)設(shè)置了每個實體類的屬性以及對應(yīng)關(guān)系,由于比較多所以我只挑選了幾個典型的。在設(shè)置實體類之前,需要使用focus命令指定要設(shè)置的實體類。
focus --class ~.domain.Pet field boolean --fieldName sendReminders --notNull --primitive field string --fieldName name --notNull --sizeMin 1 field number --fieldName weight --type java.lang.Float --notNull --min 0 field enum --fieldName type --type ~.domain.reference.PetType --notNull field set --fieldName visits --type ~.domain.Visit focus --class ~.domain.AbstractPerson field string --fieldName firstName --sizeMin 3 --sizeMax 30 field string --fieldName lastName --notNull --sizeMin 3 --sizeMax 30 field string --fieldName address --notNull --sizeMax 50 --sizeMin 1 field string --fieldName city --notNull --sizeMax 30 field string --fieldName telephone --notNull field string --fieldName homePage --sizeMax 30 field string --fieldName email --sizeMax 30 --sizeMin 6 field date --fieldName birthDay --type java.util.Date --notNull
然后設(shè)置實體類之間的投影關(guān)系并設(shè)置JPA Repository。
entity projection --class ~.domain.VetInfo --entity ~.domain.Vet --fields id,firstName,lastName,specialty --entityFormatExpression "#{firstName} #{lastName}" repository jpa --entity ~.domain.Vet --interface ~.repository.VetRepository --defaultReturnType ~.domain.VetInfo repository jpa --all --package ~.repository service --all --apiPackage ~.service.api --implPackage ~.service.impl
然后是設(shè)置DTO(數(shù)據(jù)傳輸對象),它和頁面中的表單等信息對應(yīng),然后在后臺轉(zhuǎn)換為相應(yīng)的實體類。在這里還可以指定finder,也就是查詢條件,查詢條件的規(guī)則請參考Spring Data JPA的相關(guān)內(nèi)容。
dto --class ~.domain.PetNameAndWeightFormBean field string --fieldName name field number --fieldName weight --type java.lang.Float finder add --entity ~.domain.Pet --name findByNameAndWeight --formBean ~.domain.PetNameAndWeightFormBean
然后是設(shè)置Spring Web MVC,這里指定Thymeleaf作為視圖層,并為所有控制器生成JSON和Thymeleaf視圖。
web mvc setup web mvc view setup --type THYMELEAF web mvc controller --all --responseType JSON web mvc controller --all --responseType THYMELEAF
然后是生成查詢和詳情頁面。這里針對前面設(shè)置的所有查詢條件生成相應(yīng)的查詢頁面,然后生成指定實體類的詳情頁面。最后指定了頁面語言,目前好像只支持英語和西班牙語。
// Publishing finders web mvc finder --all --responseType THYMELEAF // Adding details web mvc detail --entity ~.domain.Owner --field pets --views list,show,findByCityLike --responseType THYMELEAF web mvc detail --all --views list,show --responseType THYMELEAF web mvc language --code es
然后使用了Spring Security保護(hù)了一下程序。第一行的是使用Spring Security的默認(rèn)配置,用戶名是user,密碼是打印在控制臺的隨機(jī)字符串。第二行配置了一下用戶權(quán)限,只有管理員角色的用戶才能執(zhí)行刪除操作。
security setup --provider DEFAULT security authorize --class ~.service.impl.OwnerServiceImpl --method delete.* --roles ADMIN
然后啟用了審計功能,程序會自動記錄相應(yīng)實體類的編輯時間和編輯者。
jpa audit setup jpa audit add --entity ~.domain.Pet jpa audit add --entity ~.domain.Owner jpa audit add --entity ~.domain.Visit jpa audit add --entity ~.domain.Vet
然后啟用了Web服務(wù)端點功能,這些端點可以在/servicesURL下查看。
ws endpoint --service ~.service.api.OwnerService --sei ~.ws.api.OwnerWebService --class ~.ws.endpoint.OwnerWebServiceEndpoint --config ~.config.WsEndpointsConfiguration ws endpoint --service ~.service.api.PetService --sei ~.ws.api.PetWebService --class ~.ws.endpoint.PetWebServiceEndpoint --config ~.config.WsEndpointsConfiguration
最后自動為這些實體類和服務(wù)生成單元測試和集成測試。
// Generating unitary tests for all entities test unit --class ~.domain.Owner test unit --class ~.domain.Pet test unit --class ~.domain.Vet test unit --class ~.domain.Visit // Repository integration tests test integration --class ~.repository.VetRepository test integration --class ~.repository.OwnerRepository test integration --class ~.repository.VisitRepository test integration --class ~.repository.PetRepository // Controller integration tests test integration --class ~.web.OwnersCollectionJsonController test integration --class ~.web.PetsItemJsonController test integration --class ~.web.VetsCollectionThymeleafController test integration --class ~.web.VisitsItemThymeleafController
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“spring Roo怎么用”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!