都說roller在國外是二次開發(fā)博客系統(tǒng)的首選,但是下載源代碼之后發(fā)現(xiàn)是它是基于netbeans項目結構開發(fā)的。平時用習慣了Eclipse,所以想搬到MyEclipse上面,但沒有想到居然那么不容易,折騰了整整一天,才最終跑起來。網(wǎng)上的參考信息太少,大概都是那二三篇的轉貼,全部結合起來就差不多可以解決,借此總結一下,希望用到的朋友有參考作用!
1. 準備環(huán)境
MyEclipse 6.0
JDK 1.6.0_05
Tomcat 5.5.27 (建議用5.5以上版本)
Roller 4.0.1
2. 下載Roller
從Roller的主頁http://roller.apache.org/ 下載最新的roller版本,目前是4.0.1,同時下載源代碼包和官筆發(fā)布程序包的zip,分別為apache-roller-src-4.0.1.zip和apache-roller-4.0.1.zip。
下載發(fā)布程序的原因是源源代碼包里有一些內容和發(fā)布包不一致,導致源代碼在Eclipse中編譯后在運行時會報錯,因為對源代碼不熟悉,所以還無法定位到錯誤的原因所在。另外一些配置文件只有在它官方的發(fā)布包中才有,一會要用到它。
3. 搭建項目環(huán)境
在MyEclipse中新建一個Web項目,命名為roller,J2EE環(huán)境選擇1.4。
解壓縮roller的二個包,為了說明的方便,我們把apache-roller-src-4.0.1.zip的解壓縮后目錄叫做roller-src,把apache-roller-4.0.1.zip的解壓縮后目錄叫做roller-bin。
①把roller-src/apps/weblogger/src/java目錄下的org整個目錄的源文件復制到項目中的src里面;
②向lib中添加jar文件。二種方法,可以從roller-src中的tools目錄中逐個目錄地把所有的jar文件拷貝出來,為了簡單起見,還是從它的發(fā)布程序中直接拿更方便,從roller-bin中的WEB-INF/lib下面的所有jar都復制出來,放到我們的項目中的lib中去;
③ roller默認是使用MySQL數(shù)據(jù)庫,但是lib里面缺少MySQL的JDBC驅動,所以還要自己從網(wǎng)上下載驅動的jar,添加到WEB-INF/lib中,如果你是使用的其它數(shù)據(jù)庫,同樣需要手動下載它對應的驅動程序;
④從roller-bin中復制除了WEB-INF目錄以外的所有文件,粘貼到我們項目中的WebRoot下面,這些是頁面文件和一些資源文件;
⑤復制roller-bin中的WEB-INF目錄下除了classes外的所有文件到我們項目中的WEB-INF目錄下,覆蓋掉默認的web.xml,你還可以發(fā)現(xiàn)它的一些jsp文件是放在WEB-INF下面的,起到很好的保護作用,roller是基于struts2開發(fā)的;
⑥從roller-bin中的WEB-INF/classes目錄中,復制除了org目錄外的所有文件,到我們項目中的src里面,這些是系統(tǒng)的配置文件,包括了國際化資源、struts配置、log配置、數(shù)據(jù)庫腳本等等。
⑦ roller還用到了郵件功能,需要把activation.jar,mail.jar二個j2ee的jar復制到tomcat的common/lib目錄下,如果沒有這一步,可能啟動初始化會失敗!導致應用無法正常運行。
到這里,所有的文件就已經(jīng)全部搬到MyEclipse上面了,接下來要修改一些內容使用我們的項目能正常部署。
4. 修改部分內容
①在我們項目的src中新建一個名稱為roller-custom.properties的文件,roller采用這個擴展配置現(xiàn)覆蓋系統(tǒng)的默認配置。網(wǎng)上有些說要把這個文件放到tomcat的common/classes中,其實不用的,只要放在classpath中能找到就行了,所以我們把它放在我們的src目錄下面,方便修改,在該文件中添加如下內容:
installation.type=auto
database.configurationType=jdbc
database.jdbc.driverClass=com.mysql.jdbc.Driver
database.jdbc.connectionURL=jdbc:mysql://localhost:3306/rollerdb?autoReconnect=true&useUnicode=true&characterEncoding=utf-8&mysqlEncoding=utf8
database.jdbc.username=scott
database.jdbc.password=tiger
mail.configurationType=properties
mail.hostname=smtp-server.example.com
mail.username=scott
mail.password=tiger
注意database.jdbc.connectionURL這個配置后面需要帶上上面編碼的參數(shù),不然安裝的過程可能會出現(xiàn)一些亂碼。修改url和username,password這些,如果你有能正常使用的郵箱服務器,也填上。
②創(chuàng)建MySQL數(shù)據(jù)庫,名稱為rollerdb,并指定編碼為UTF-8。如果你使用的是root用戶,則不用授權,如果不是,則需要為用戶授權,下面是一個示例:

啟動roller的時候它會查詢數(shù)據(jù)庫是否已經(jīng)初始完成,如果沒有,它會自動進入安裝頁面,引導用戶進行安裝,做得非常人性化。
③修改部分源代碼。org.apache.roller.weblogger包里面的pojos包是有問題的!剛開始的時候老是無法啟動,報錯提示的是JPA的一個異常,根本不知道如何解決,后來在CSDN上找到一篇文章,說是pojos這個包的源碼有問題,可能跟發(fā)布包中的版本不一致,所以需要用變態(tài)一點的處理辦法。

在我們的項目WEB-INF/lib中,找到roller-business.jar和roller-web.jar(如上圖所示),這二個jar其實就是我們src中的所有java文件的編譯打包,為了不重復,先把roller-web.jar刪除掉,然后用winrar打開roller-business.jar,刪除pojos以外的其它四個包和那個WebloggerException.class。這樣,其它代碼可以正常編譯!
下面是最終的基本結構截圖(僅參考):
WeRoot目錄截圖

Src目錄截圖:

5. 其它補充說明
按照上面的步驟,項目結構就基本上正常搭建了,真是費心費力!NetBeans下面沒有試過,興許會比這個簡單許多!反正都習慣Eclipse了,就都移過,后面再花些時間研讀一下它的源代碼,網(wǎng)上說是非常好的學習例子。
① Roller的系統(tǒng)全局配置文件是放在org.apache.roller.weblogger. org.apache.roller.weblogger.config包中的roller.properties中的。在這里能找到各項系統(tǒng)的配置,我們自己手動創(chuàng)建的roller-custom.properties是用來覆蓋一些常用屬性的。
② src下面的dbscripts是所有數(shù)據(jù)庫的SQL腳本,apache-roller-src-4.0.1.zip中提供的腳本是不完整的!所以需要使用正式發(fā)布包的腳本,它帶了數(shù)據(jù)庫的初始腳本,由系統(tǒng)自動引導創(chuàng)建,還有許多版本升級的補充腳本。
③默認的log配置是用文件形式,保存在tomcat的的logs目錄中,名稱為roller.log的,如果你啟動的過程遇到問題,請到這里去查看啟動日志,分析一下異常的原因。
④ roller-custom.properties中配置的郵箱主機和用戶名密碼等,如果無法正常連接,它初始化時會報錯,但是不會影響正常啟動,前提是你必須把activation.jar,mail.jar這二個文件放到tomcat里面。
⑤在調試的過程中發(fā)現(xiàn)org.apache.roller.weblogger.business.WebloggerImpl類的創(chuàng)建方法中有加載roller-verion.properties,但是在我們的src中沒有找到這個文件,原來是在roller-business.jar中包含了。好像另一個類也包含這一句啟動的初始代碼,如果找不到這個類,會拋出空指針Exception,同樣導致整個應用啟動失敗。所以剛開始的時候生硬地在WebloggerImpl類中115行加載了一段異常處理代碼如下:

當然,如果你已經(jīng)包含了roller-version.properties文件,這個異常是不會存在的!
⑥ Roller的文檔非常齊全,圖文并茂,多多閱讀,就可以了解它的使用方法。IBM 開發(fā)者論壇就是基于它進行開發(fā)的,的確非常強大,想了解struts2、JPA、Spring、Acegi、Velocity等主流技術的都可以從這里找到示例,不過要多花些時間,從其它方面,比如結構劃分、代碼規(guī)范、theme切換等,都可以學習到很多東西。
⑦Roller Architecture(摘自網(wǎng)絡)
Roller Web:Web and UI Layer
* Editor UI via Struts and JSP,blog and feed rendering via Velocity
* Feed parsing via ROME, Blogger API via Apache XML-RPC
Roller Beans:Business and Persistence Layer
* Hibernate/JPA for DBMS,Lucene for search

多多學習,愿和大家共同分享!^_^
這里打包一個PDF文件提供下載: 將Apache Roller部署到MyEclipse上面
剛進場的時候戲就落幕