MyIgnorance 2011-10-10
转载自lontoo
spingframework-2.5.5
struts-2.0.11
sitemesh-2.4.1
hibernate-3.2.6(antlr-2.7.7.jar)
weblogicserver10.3.1(多语言版本—中文版)【javaversion"1.6.0_11"】
1、包antlr冲突问题
org.hibernate.queryexception:
classnotfoundexception:org.hibernate.hql.ast.hqltoken
引起这个问题的原因是包antlr2.6.1.jar在weblogic10.3中与项目中hibernate3.x用来解析sql语句的包antlr-2.7.7.jar冲突了。
大致有3种方式可以解决这类问题:
1)在启动weblogic时,优先启动项目中使用到的antlr-2.7.7.jar的文件。在weblogic启动文件的classpath上优先增加antlr-2.7.7.jar文件。如下:
setsave_classpath=.;d:\antlr-2.7.7.jar;%classpath%
注意:
你必须把antlr-2.7.7.jar拷贝到d:目录下或者其他你自己设定的目录名。
2)在hibernate.properties或者hibernate-cfg.xml,或者db-jdbc.properties中设置一个属性hibernate.query.factory_class的值为
org.hibernate.hql.classic.classicquerytranslatorfactory
注意:
●选择hibernate3.x的查询翻译器:
org.hibernate.hql.ast.astquerytranslatorfactory
●选择hibernate2.x的查询翻译器
org.hibernate.hql.classic.classicquerytranslatorfactory
3)在/web-inf目录下增加或者修改weblogic.xml文件。
<container-descriptor>
<prefer-web-inf-classes>true</prefer-web-inf-classes>
</container-descriptor>
注意:
●这个方法不是推荐的,因为这个设置可能会引起jstl的设置冲突。
2、servlet2.5规范问题
如果使用servlet2.5规范来配置web.xml文件。在系统启动时出现以下错误:
java.lang.illegalargumentexception:illeagalcombination-mode.payloadandprovider<javax.xml.soap.soapmessage>
atcom.sun.xml.ws.server.provider.providerendpointmodel.<init>(providerendpointmodel.java:111)
atcom.sun.xml.ws.server.provider.providerinvokertube.create(providerinvokertube.java:63)
解决的方法
1)使用web.xml2.4的规范而不是使用web.xml2.5规范;
2)在weblogic.xml中设置(参见上面的说明):
<prefer-web-inf-classes>true</prefer-web-inf-classes>;
3、装饰器无法正常工作
装饰器无法正常工作,只能返回请求页面,不会对页面进行任何装饰。比如提交一个struts2请求/portal/abc.do,同时也设置了sitemesh过滤器映射这个请求,以及在decorators.xml中也设置了装饰器,比如:
<decoratorname="foredecorator"page="template.jsp">
<pattern>/portal/abc.do</pattern>
</decorator>
现在假设struts2请求/portal/abc.do将会返回到一个页面abc.jsp页面。结果,页面只返回了abc.jsp页面上的数据,而没有被template.jsp页面进行装饰。通过查看源代码发现。在准备装饰之时,weblogic的request.getservletpath()得到是abc.jsp,而不是/portal/abc.do。
因此在decorators.xml并不能找到需要装饰的mapping。除非将<pattern>/portal/abc.do</pattern>修改为:
<pattern>/abc.jsp</pattern>
是可以被映射并装饰了。
解决的方法
修改sitemesh的对应的decoratormapping源代码。在这里这个文件是:
com\opensymphony\module\sitemesh\mapper\configdecoratormapper.java
修改这个文件。使用request.getrequesturi()代替request.getservletpath()来获得待匹配的url。
4、sitemesh乱码问题
关于sitemesh乱码问题,除了与tomcat环境下的设置以外。比如:
通过过滤器设置:
request.setcharacterencoding(encoding);
response.setcharacterencoding(encoding);
jsp文件设置:
<%@pagecontenttype="text/html;charset=utf-8"pageencoding="utf-8"%>
weblogic针对sitemesh方面还有3个地方出现乱码:
1)在装饰器文件中使用<decorator:body/>乱码。这个是最常用的,也就是最常见的乱码问题。
2)page:applydecorator,指定了待装饰的jsp文件,比如:t1.jsp:
<page:applydecoratorpage="t1.jsp"name="t1decorator"/>
这样t1.jsp渲染后出现乱码。
3)一个请求通过了sitemesh过滤器,但同时又没有找到对应的装饰器(同时并不在excludes中指定),这样就是使用默认的装饰器(nodecorator)进行直接输出。
com.opensymphony.sitemesh.webapp.decorator.nodecorator
虽然是各种不同的情况,但原因都有些类似,就是在weblogic环境下,sitemesh在装饰页面时,如果response的contenttype为null,则使用java虚拟机属性值"file.encoding",而该值与操作系统相关,在windows系统下,该值=gbk.由于页面本身是utf-8编码的,经过sitemesh装饰后,使用gbk编码转换,产生乱码。
解决的方法
既然跟file.encoding有关系,那么就直接设置这个系统属性可以解决上面的全部问题。解决如下:在weblogic启动文件的启动参数上增加-dfile.encoding。如下:
setsave_java_options=%java_options%-dfile.encoding=utf-8
注意:
●这个方法简单明了,而且不用修改其他方面;
●但是,如果这样设置的话,weblogic本身的启动等相关信息就乱码了。
因此,在下面使用其他的方式来解决上面的3个问题:
1)通过查看源代码,发现进行内容装饰之前需要进行对内容字节转换成字符串,在转换的时候,如果没有获得编码,那么就是用file.encoding。因此,可以修改这个文件,使默认使用的编码为”utf-8”.
com.opensymphony.module.sitemesh.filter.textencoder
2)page:applydecorator,指定了待装饰的jsp文件,那么,同时需要指定这个文件使用的编码。如下:
<page:applydecoratorpage="t1.jsp"name="t1decorator"encoding="utf-8"/>
3)针对第3个乱码问题,可以通过修改如下文件:
com.opensymphony.sitemesh.webapp.decorator.nodecorator
让输出的字符串作为utf-8的方式直接输出到response中。
5、<c:import…>乱码问题
所包含的文件需要使用charencoding="utf-8"进行限定。
<c:importurl="/portal/block/userblock11.jsp"charencoding="utf-8"/>