最近工作很忙,开发任务很大,遇到的问题也千奇百怪,现总结如下,希望能够帮到各位.
(1)设置struts 的默认action.目的是访问http://localhost:8080/shop_goods ,自动跳转到http://localhost:8080/shop_goods/logininput.action
于是我在struts 配置文件中增加了
<default-action-ref name="logininput" />
但是始终达不到目的,检查了好多遍,语法都没有问题,在网上看了好多资料,配置完全一样,但是还是跳转不到默认action.
最后才发现有猫腻.
我在web.xml中配置struts过滤器如下:
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.ng.filter.strutsprepareandexecutefilter
</filter-class>
</filter>
<filter-mapping>
<url-pattern>*.action</url-pattern>
</filter-mapping>
后来我把红色部分改为/*就好了.
(2)ssh项目,启动tomcat时报错
详细错误信息:
org.springframework.beans.factory.beancreationexception: error creating bean with name 'sessionfactory' defined in class path resource [com/tdr/mbs/endpoint/config/core/dbenv.xml]: invocation of init method failed; nested exception is org.hibernate.duplicatemappingexception: duplicate class/entity mapping com.wh.service.loginservice
意思就是tomcat启动时发现有两份com.wh.service.loginservice ,然后它就不知道到底要加载哪个class了.
为什么会这样呢?
我进到tomcat部署的项目的lib下一看,发现有两个不同版本的jar包:wh_service-0.0.1.jar,wh_service-0.0.2.jar
因为我的项目是使用maven构建,依赖的另一个模块也是我们开发的,而且在不断升级.从0.0.1升级到0.0.2时,原来的jar包没有删除.
此时如何解决呢?
(1)直接进入tomcat 部署的项目目录lib下,把旧版本的jar包删除;
(2)先把项目从eclipse中remove,
然后clean,然后在add到eclipse的tomcat下
最后再启动tomcat.
(3)maven 打包发布时,发现最新的代码没有打在包里面
明明已经是最新的代码了,为什么没有打进去呢?
原因是项目的src\main\webapp\web-inf目录下有一个classes文件夹,里面的class等文件还是旧的,maven打包时没有自动替换它
解决方法:直接删除上述classes目录.
(4)终于体会了logger日志(使用日志框架如log4j)的好处
之前和同事联调项目时出现了问题,他访问我的web服务,总是返回空白,突然想到是ip限制,于是我把它的ip加到了白名单.但是还是返回空,为什么呢?
看tomcat 日志文件(使用log4j),并没有发现exception啊,真是奇怪了.
当时已经绝望了,又看了一眼日志,发现有warning级别的日志,一细看终于发现了原因,原来是他请求时content-type不对,应该是application/json,而他传的是text/xml;charset=utf-8,
使用hibernate 映射文件.hbm.xml自动创建表,但是无法创建,不知道为什么,
后来才发现hbm.xml中多了一个属性,即hbm.xml中配置一个column 实体类中没有.
之前的总结:
http://hw1287789687.iteye.com/blog/2034439
http://hw1287789687.iteye.com/blog/2019501
http://hw1287789687.iteye.com/blog/2005427
http://hw1287789687.iteye.com/blog/2002293
http://hw1287789687.iteye.com/blog/1997640