天天看点

java web开发过程中出现的一些诡异问题

最近工作很忙,开发任务很大,遇到的问题也千奇百怪,现总结如下,希望能够帮到各位.

(1)设置struts 的默认action.目的是访问http://localhost:8080/shop_goods ,自动跳转到http://localhost:8080/shop_goods/logininput.action 

于是我在struts 配置文件中增加了

java web开发过程中出现的一些诡异问题

<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时报错

详细错误信息:

java web开发过程中出现的一些诡异问题

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,

java web开发过程中出现的一些诡异问题

然后clean,然后在add到eclipse的tomcat下

java web开发过程中出现的一些诡异问题

 最后再启动tomcat.

(3)maven 打包发布时,发现最新的代码没有打在包里面

明明已经是最新的代码了,为什么没有打进去呢?

原因是项目的src\main\webapp\web-inf目录下有一个classes文件夹,里面的class等文件还是旧的,maven打包时没有自动替换它

java web开发过程中出现的一些诡异问题

 解决方法:直接删除上述classes目录.

(4)终于体会了logger日志(使用日志框架如log4j)的好处

之前和同事联调项目时出现了问题,他访问我的web服务,总是返回空白,突然想到是ip限制,于是我把它的ip加到了白名单.但是还是返回空,为什么呢?

看tomcat 日志文件(使用log4j),并没有发现exception啊,真是奇怪了.

当时已经绝望了,又看了一眼日志,发现有warning级别的日志,一细看终于发现了原因,原来是他请求时content-type不对,应该是application/json,而他传的是text/xml;charset=utf-8,

java web开发过程中出现的一些诡异问题

使用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