Opentaps 1.5.0启动后的一个访问错误的解决办法

3 篇文章 0 订阅

 今天下载了开源的ERP+CRM软件,部署过程有几点心得,说一下:


1.下载完软件,运行ant 之后报错,这时把build.xml文件中报错的行failοnerrοr="true"去掉


2.重新执行ant run-install,这时会报找不到字符集utf-8和collation
查看我的数据库的show character set和show collation,按照我本地数据库上的
重新修改配置文件上的

3.这时编译成功,启动脚本之后,输入http://localhost:8080/opentaps
之后,出现

java.util.regex.PatternSyntaxException: Unexpected internal error near index 1
\
 ^
	java.util.regex.Pattern.error(Pattern.java:1713)
	java.util.regex.Pattern.compile(Pattern.java:1466)
	java.util.regex.Pattern.<init>(Pattern.java:1133)
	java.util.regex.Pattern.compile(Pattern.java:823)
	java.lang.String.split(String.java:2293)
	java.lang.String.split(String.java:2335)
	org.ofbiz.webapp.control.ConfigXMLReader.injectControllerIfNeeded(ConfigXMLReader.java:81)
	org.ofbiz.webapp.control.ConfigXMLReader.getControllerConfig(ConfigXMLReader.java:133)
	org.ofbiz.webapp.control.RequestHandler.getControllerConfig(RequestHandler.java:97)
	org.ofbiz.webapp.control.RequestHandler.getDefaultErrorPage(RequestHandler.java:647)
	org.ofbiz.webapp.control.ControlServlet.doGet(ControlServlet.java:239)
	javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
	javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
	org.apache.jasper.runtime.PageContextImpl.doForward(PageContextImpl.java:706)
	org.apache.jasper.runtime.PageContextImpl.forward(PageContextImpl.java:677)
	org.apache.jsp.index_jsp._jspService(index_jsp.java:57)
	org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
	javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
	org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:377)
	org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
	org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
	javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
	org.ofbiz.webapp.control.ContextFilter.doFilter(ContextFilter.java:270)


错误,这个问题是框架的不稳定造成的,修改一下ConfigXMLReader.java文件中方法injectControllerIfNeeded的81行将代码File.spector更改为"/"
重新执行ant -run-install-extseed编译并启动 就OK了!

 

还有一种方案, 个人比较喜欢, 在opentaps目录里的 framework\base\src\org\ofbiz\base\util\FileUtil.java 第49行后面添加如下代码:

public class FileUtil {

    public static final String separator = "/";   /* 此行为新添代码 */

    public static final String module = FileUtil.class.getName();

    ....... 此处省略N行 .......

}


并且把ConfigXMLReader.java的第81行由:

for (String a : url.toString().split(File.separator)) {

改为:

for (String a : url.toString().split(FileUtil.separator)) {

这样看起来比较舒服.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
win7 安装Opentaps 1.5 以下是在安装前的一些文件修改和操作 1)修改framework\entity\config\entityengine.xml 文件 a)把<delegator name="default" entity-model-reader="main" entity-group-reader="main" entity-eca-reader="main" distributed-cache-clear-enabled="false"> <group-map group-name="org.ofbiz" datasource-name="localderby"/>(53、54行)的localderby修改为localmysql b)把<datasource name="localmysql" 段(314行)做以下修改: table_tye="InnoDB" 修改为 Engine="InnoDB" character-set="lantin1" 修改为 character-set="utf8" collate="lantin1_general_cs" 修改为 collate="utf8_general_ci" jdbc-uri="jdbc:mysql://127.0.0.1/ofbiz?autoReconnect=true&useOldAliasMetadataBehavior=true" 中的ofbiz修改为opentaps //opentaps为创建的数据库名字 jdbc-username="ofbiz" 和 jdbc-password="ofbiz" 中的ofbiz修改为mysql上创建了的用户名和密码 c)修改build.properties文件,把里面的内存值减小一半(如果内存是4G以上就不用修改了) d)把 \framework\webapp\src\org\ofbiz\webapp\controlfor\ConfigXMLReader.java文件中的 81行 for (String a : url.toString().split(File.seperator)) { 中File.seperator修改为 "/"   e)打开\opentaps\opentaps\opentaps-common\build-aspects.xml文件,将以下三行注释掉 <jar jarfile="${ofbiz.dir}/framework/entity/build/lib/ofbiz-entity.jar" update="true" basedir="${build.dir}/classes/" includes="META-INF/aop.xml" /> <jar jarfile="${ofbiz.dir}/framework/common/build/lib/ofbiz-common.jar" update="true" basedir="${build.dir}/classes/" includes="META-INF/aop.xml" /> <jar jarfile="${ofbiz.dir}/applications/order/build/lib/ofbiz-order.jar" update="true" basedir="${build.dir}/classes/" includes="META-INF/aop.xml" /> f) 如果Mysql 版本太低,会导致表无法创建, 解决方法如下   framework\entity\src\org\ofbiz\entity\jdbc下的DatabaseUtil.java   将createTable方法中的    if (UtilValidate.isNotEmpty(this.datasourceInfo.tableType)) { sqlBuf.append(" TYPE "); sqlBuf.append(this.datasourceInfo.tableType); }   中的TYPE修改为ENGINE

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值