一、必要的軟體環境
1、jakarta-tomcat-5.0.28.exe
2、mysql-5.5.22-win32.msi
3、apache-ant-1.8.3-bin.zip
4、xplanner-0.7b7b-war
經過測試以上版本相容
漢化檔案:ResourceBundle_zh_CN.properties
二、ant 的安裝
1、配置環境變量:我的電腦----屬性-----進階----環境變量
如:ANT_HOME:D:\apache-ant-1.8.3
PATH:%ANT_HOME%\bin (為了友善在dos環境下操作)
2、檢視是否安裝成功:在dos視窗中輸入指令ant,若出現結果
Buildfile:build.xml does not exist!
Build failed
說明ant安裝成功!因為ant預設運作build.xml檔案,這個檔案需要我們建立。
3、使用:
(1)在D盤根目錄下建立build.xml
<?xml version="1.0" encoding="GBK"?>
<project name="測試腳本" default="copyfile" basedir="." >
<target name="copyfile">
<copy file="d:/a.txt" todir="e:/Temp" overwrite="true" />
</target>
</project>
(2)在D盤根目錄下建立檔案a.txt。
(3)進入dos,
d:
<a href="http://blog.51cto.com/attachment/201204/131938771.png" target="_blank"></a>
三、mysql的安裝
安裝mysql5.5.22,有幾步根據實際需要改一下.
a.選擇詳細安裝模式
<a href="http://blog.51cto.com/attachment/201204/132013372.png" target="_blank"></a>
b.選擇server Macheine
<a href="http://blog.51cto.com/attachment/201204/132126818.png" target="_blank"></a>
c、選擇DSS模式
<a href="http://blog.51cto.com/attachment/201204/132146195.png" target="_blank"></a>
d.選擇預設字元集為utf-8模式
<a href="http://blog.51cto.com/attachment/201204/132200630.png" target="_blank"></a>
e.配置資料庫的預設通路賬戶
<a href="http://blog.51cto.com/attachment/201204/132214266.png" target="_blank"></a>
f、配置mysql環境變量:我的電腦----屬性-----進階----環境變量
PATH:C:\Program Files\MySQL\MySQL Server 5.5\bin(為了友善在dos環境下操作)
配置成功顯示如下
<a href="http://blog.51cto.com/attachment/201204/132318905.png" target="_blank"></a>
四、tommcat安裝
安裝部署省略
五、XPlanner安裝
步驟:
1、建立資料庫xplanner及賦權
# mysql -u root -p
Enter password:
mysql> create database xplanner character set utf8;
mysql>create user xplauser identified by 'xplanner';
mysql>grant all privileges on xplanner.* to xplauser@'%' identified by 'xplanner' with grant option;
mysql>grant all privileges on xplanner.* to xplauser@'localhost' identified by 'xplanner' with grant option;
mysql> flush privileges;
2、把XPlanner解壓到D盤修改xplanner/web-inf/classes/xplanner.properties 和xplanner-custom.properties檔案,改成相應的資料庫連接配接
hibernate.dialect=com.technoetic.xplanner.db.hibernate.XPlannerMySQLDialect
hibernate.connection.driver_class=com.mysql.jdbc.Driver
hibernate.connection.url=jdbc:mysql://localhost/xplanner?autoReconnect=true&useUnicode=true&characterEncoding=UTF8
hibernate.connection.username=xplauser
hibernate.connection.password=xplanner
3、運作cmd,進入d:\xplanner-0.7b7b-war目錄,ant create.db.schema.script會在installer目錄下生成檔案
<a href="http://blog.51cto.com/attachment/201204/132509326.png" target="_blank"></a>
<a href="http://blog.51cto.com/attachment/201204/132535504.png" target="_blank"></a>
BUILD SUCCESSFUL 表示成功。
4、將 installer 目錄下的 hibernate_schema.sql 的資料跑一遍,會在資料庫産生需要的表
這個腳本檔案每條語句都沒有用分号包住,還要自己修改成mysql可執行的格式(語句後面添加';')
<a href="http://blog.51cto.com/attachment/201204/132547632.png" target="_blank"></a>
5、運作cmd,進入d:\xplanner-0.7b7b-war目錄,ant bootstrap 建立 sysadmin 的資料進 mysql
<a href="http://blog.51cto.com/attachment/201204/132559837.png" target="_blank"></a>
<a href="http://blog.51cto.com/attachment/201204/132611540.png" target="_blank"></a>
如圖執行成功。
6、删除 \WEB-INF\classes\patches 下所有資料
7、 xplanner Copy 到 Tomcat\webapps目錄下
8、替換内容
打開 /xplanner/WEB-INF/classes/spring-beans.xml
找到 bean id="metaRepository"
替換成如下樣子
<property name="repositories">
<bean class="java.util.HashMap">
<constructor-arg>
<map>.....</map>
</constructor-arg>
</bean>
</property>
就是把<map>...</map>用外面兩個屬性包住.
9、foot.jsp頁面報錯,JSP頁面報錯其實挺簡單的,就是引号裡面套了個引号,把裡面的引号轉義下就OK了。
10、漢化,把檔案ResourceBundle_zh_CN.properties
安裝成功如下: 賬戶預設為 sysadmin 密碼預設為 admin
<a href="http://blog.51cto.com/attachment/201204/132806984.png" target="_blank"></a>
問題:
1、重新安裝mysql會不能start service
原因是mysql沒有卸除幹淨
除了路徑C:\Program Files\MySQL\MySQL Server 5.5
還有C:\Documents and Settings\All Users\Application Data\MySQL\MySQL Server 5.5\data 也要清除幹淨
原來是spring-beans.xml檔案中的問題
就是這個部分
<bean id=”metaRepository” class=”com.technoetic.xplanner.domain.repository.MetaRepositoryImpl”>
<property name=”repositories”>
<map>
com.technoetic.xplanner.domain.repository.MetaRepositoryImpl的repositories需要一個map,
spring中使用使用的實作是org.apache.commons.collections.map.LinkedMap
但是org.apache.commons.collections.map.LinkedMap實作了java.util.Map接口啊!
理論上應該的可以的啊!但是卻出現了轉化錯誤,沒有找到原因,但是找到了解決方案啊!
把<property name=”repositories”><map>……</map></property>
修改為
<property name="repositories">
<bean class="java.util.HashMap">
<constructor-arg>
<map>…..</map>
</constructor-arg>
</bean>
</property>
就可以了啊!
還有兩個問題。。。。
1.JSP頁面錯誤
WEB-INF/jsp/view/notes.jsp
原來的: <xplanner:link page="/do/delete/note" confirm('Do you want to delete note ////'" + StringUtilities.replaceQuotationMarks(StringEscapeUtils.escapeJavaScript(note.getSubject())) + "////'?')"%>'>
替換成:<xplanner:link page="/do/delete/note" confirm(/'Do you want to delete note /////'" + StringUtilities.replaceQuotationMarks(StringEscapeUtils.escapeJavaScript(note.getSubject())) + "/////'?/')"%>'>
WEB-INF/jsp/common/footer.jsp
原來的:<bean:message key="footer.message" arg0="<%=productionSupportEmail%>" arg1="<%=issueLink%>" arg2="<%=appUrl+"/do/systemInfo"%>"/>
替換成:<bean:message key="footer.message" arg0="<%=productionSupportEmail%>" arg1="<%=issueLink%>" arg2="<%=appUrl+/"/do/systemInfo/"%>"/>
2.使用者怎麼不能登陸?
ant指令: ant install.db.schema(改指令是完全可用的,隻是生成的SQL檔案每句後面沒有分号)
然後把的到得腳本在資料庫裡執行,就可以了。
資料庫的庫表結構搭建完成。網上很多地方都說到這裡,就結束。事實上并沒有完成。還需要一些初始化的工作。官網提供的腳本中,存在錯誤。那是由于0.6的版本的腳本,參合到0.7中。同時在這裡也說明一個開源的弊端。
具體初始化腳本在xplanner/WEB-INF/classes/patches目錄下。裡面的很多腳本基本上沒有用,有用的隻是patch0002_bootstrap_users_and_permissions.sql。這個資料庫腳本的主要作用就是生成一個管理者賬号和定義具體的任務規則。但是,這個官網版本執行會直接報錯(至少在mysql 5.0 下報錯)。為此,需要删除掉該腳本下的所有關于permission的插入操作。會缺少一個字段的值。
INSERT INTO permission VALUES(6,5,'%','%',0, 1);
INSERT INTO permission VALUES(7,3,'-create.project','system.project',0, 1);
INSERT INTO permission VALUES(8,3,'-create.person','system.person',0, 1);
INSERT INTO permission VALUES(9,4,'-create.project','system.project',0, 1);
INSERT INTO permission VALUES(10,4,'admin%','%',0, 1);
INSERT INTO permission VALUES(11,3,'create%','%',0, 1);
INSERT INTO permission VALUES(12,3,'edit%','%',0, 1);
INSERT INTO permission VALUES(13,3,'integrate%','%',0, 1);
INSERT INTO permission VALUES(14,3,'delete%','%',0, 1);
INSERT INTO permission VALUES(15,2,'read%','%',0, 1);
還有件重要的是,後面的positive這個字段一定要給1,否則後面你即将無法顯示相應的工程,為了這個問題,代碼都友善。
本文轉自 holy2009 51CTO部落格,原文連結:http://blog.51cto.com/holy2010/832269