XPlanner 一个基于Web的XP团队计划和跟踪工具。XP独特的开发概念如iteration、user stories等,XPlanner都提供了相对应的的管理工具,XPlanner支持XP开发流程,并解决利用XP思想来开发项目所碰到的问题。XPlanner特点包括:简单的模型规划,虚拟笔记卡(Virtual note cards),iterations、user stories与工作记录的追踪,未完成stories将自动迭代,工作时间追踪,生成团队效率,个人工时报表,SOAP界面支持。

xplanner0.7b7中文版配置过程:

1.下载xplanner0.7b7。地址:http://downloads.sourceforge.net/xplanner/xplanner-0.7b7-standalone.zip?modtime=1148353282&big_mirror=0

解压到e盘根目录。(这里以e盘为例)

2.安装mysql。 下载地址:http://ftp.stu.edu.tw/pub/Unix/Database/Mysql/Downloads/MySQL-5.1/mysql-5.1.24-rc-win32.zip

安装mysql的时候除了字符集选utf-8之外其他都是下一步,那么在C:\Program Files\MySQL\MySQL Server 5.1目录下面会有一个my.ini ,打开这个文件 在[mysqld]下添加或更改:
max_allowed_packet=1024M

这样可以保证mysql可以处理大对象。

配置完成后登陆mysql:mysql -u root -p

创建数据库:CREATE DATABASE xplanner CHARACTER SET UTF8 COLLATE utf8_general_ci

创建xplanner用户:GRANT ALL PRIVILEGES ON xplanner.* TO 'xplanner'@'localhost' IDENTIFIED BY 'xp' WITH GRANT OPTION;

如果要从一个远程服务访问mysql:GRANT ALL PRIVILEGES ON xplanner.* TO 'xplanner'@'%' IDENTIFIED BY 'xp' WITH GRANT OPTION;

3.配置xpanner的数据库连接:

找到E:\xplannerstd\webapps\ROOT\WEB-INF\classes\xplanner.properties

修改下面的数据库参数(前面的#号要去掉):

hibernate.connection.dbname=xplanner
hibernate.connection.url=jdbc:mysql://localhost:3306/xplanner
hibernate.connection.username=xplanner
hibernate.connection.password=xp
xplanner.migration.databasetype=mysql
xplanner.migration.patchpath=patches:com.technoetic.xplanner.upgrade:com.technoetic.xplanner.security.install

此时xplanner应该就可以启动了。你可以在安装目录下运行:startup_xplanner.bat。然后访问:http://localhost:7070,应该可以看到xpanner的英文界面。初始登陆用户:sysadmin 密码:admin

4.下载ResourceBundle_zh_CN.properties

直接下载放到E:\Tools\xplannerstd\webapps\ROOT\WEB-INF\classes目录里。重启tomcat,中文版就已经配置好了!

下载地址:http://www.rayfile.com/zh-cn/files/af26d5f3-71ba-11de-bac7-0019d11a795f/

或者: u.115.com/file/f55ef4baf8

xplanner-0.7b7b 部署问题解决

运行时总是报spring的一个配置文件出错 

是因为XPlanner部署在JDK1.6上的问题 
http://jira.codehaus.org/browse/XPR-391 

错误如下: 
ERROR - alina].[localhost].[/xplanner] - Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener 
org.springframework.beans.factory.BeanCreationException: Error creating bean with name ‘metaRepository’ defined in class path resource [spring-beans.xml]: Error setting property values; nested exception is org.springframework.beans.PropertyAccessExceptionsException: PropertyAccessExceptionsException (1 errors); nested propertyAccessExceptions are: [org.springframework.beans.TypeMismatchException: Failed to convert property value of type [org.apache.commons.collections.map.LinkedMap] to required type [java.util.HashMap] for property ‘repositories’] 
PropertyAccessExceptionsException (1 errors) 
org.springframework.beans.TypeMismatchException: Failed to convert property value of type [org.apache.commons.collections.map.LinkedMap] to required type [java.util.HashMap] for property ‘repositories’ 
at org.springframework.beans.BeanWrapperImpl.doTypeConversionIfNecessary(BeanWrapperImpl.java:839) 
at org.springframework.beans.BeanWrapperImpl.setPropertyValue(BeanWrapperImpl.java:584) 
at org.springframework.beans.BeanWrapperImpl.setPropertyValue(BeanWrapperImpl.java:469) 

原来是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" onclick='<%="return confirm('Do you want to delete note ////'" + StringUtilities.replaceQuotationMarks(StringEscapeUtils.escapeJavaScript(note.getSubject())) + "////'?')"%>'>


替换成:<xplanner:link page="/do/delete/note" onclick='<%="return 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,否则后面无法显示相应的工程,为了这个问题,代码都方便。

Xplanner使用心得http://www.doc88.com/p-16016253801.html