当被错误折磨半天后,突然找到解决办法了,那种快感……不是东京热可以给的了的……好来,不闲扯了,本文主要记录struts2在开发中会遇到的一些问题或者异常,方便后面查阅。
1. java.lang.ClassNotFoundException: org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
这个异常很明显,没有找到filter,抛出来后令我很郁闷,因为我的web.xml文件中配置是没有错的,jar包也没有漏掉。后来在网上查了下,发现问题所在了,我们写项目一般都会自己新建一个User Library方便管理jar包,然后将该User Library引到工程中来,那么问题来了:编译是没有问题的,但是启动tomcat服务器的时候,就会抛出上面的异常。
问题的根源:编译器之所以找不到jar包,是因为myeclipse在发布项目的时候并没有将我们引进来的jar包拷贝到WEB-INF下面的lib文件夹中,导致启动tomcat服务器时找不到jar包。
问题的解决:既然知道问题所在了,那么就好解决了,主要有两种方式可以解决:
1. 很明显,既然在WEB-INF的lib目录找不到jar包,那么我们添加jar文件的时候直接添加到WEB-INF的lib目录下即可解决。
2. 设置myeclipse项目发布的选项,在工程上右击->properties,会弹出下面窗口:
选择Deployment Assembly,然后点击Add按钮:
选择java Build Path Entries,然后next
选择要部署到WEB-INF/lib目录下的jar包,这里主要是struts2的包
finish后,就可以看到,已经将该包里面的jar文件拷贝到WEB-INF/lib目录下了,重新启动tomcat就可以了。
tomcat启动时出现的问题很多时候都是没有找到相应的jar包,所以要考虑到可能会是这里的这个原因。
这篇博文会持续更新Struts2在开发中所遇到的异常。
2. Struts在打包json格式传到前台的懒加载异常问题
Hibernate中如果出现了级联查询,就可能出现懒加载问题,比如我现在有个Account(管理员)类、Category(商品类别)和Product(商品)类,从做到右都是一对多的关系,而且从右到左都是设置了@ManyToOne(fetch=FetchType.LAZY。我现在要把商品信息查出来打包成json格式传到前台,我在后台使用查询语句为:from Product p left join fetch p.category where p.name like:name.这样就可以把Product查出来了,然后Product中的Category也放进去了,但是Category中的Account不是实际对象,是暂时的代理对象,这点很好理解,因为我就查了Product而且只级联了Category,至于Category和Account就根据实际配置了(LAZY)。
现在将查询出来的product放到Map中,然后转成json格式返回到前台肯定会出现懒加载问题,因为在转json的过程中会拿Account对象,但是此时session已经关闭了,所以会报错,有个很直接但是不太好的解决办法就是将Category中的LAZY改成EAGER,这样就能把Account的信息也查出来,但是这样不好。所以我们用另一种办法:在struts.xml中设置一下黑名单,在转json格式的时候使用正则表达式将category中的account过滤掉,就不会去查account对象了,就不会有懒加载问题了。如下:
到这里,应该就没问题了。但是在我的项目中还是报懒加载异常,也就是说我这样配置后根本没有起作用。但是理论上,这样配置后就OK了,就可以正常的把数据打包成json格式传给前台了。这问题困扰了我2天,后来索性先将LAZY改成EAGER,先把项目往下做。
今天我在另一个Hibernate异常中,联系到了这里的异常,解决了!Hibernate中今天我要调用get方法获取商品的信息,无法获取到,后台的控制台没有任何消息,由于我开启了dev模式,前台显示了错误信息:
java.lang.ClassCastException:cn.it.shop.model.Product_$$_javassist_0 cannot be cast to javassist.util.proxy.Proxy
无法转成代理??为啥要转成代理呢?一般不都是代理无法转成实际对象么?于是我上网搜索了一下,这个问题可能是由于项目中的一个javassist的jar包冲突了,我去工程中检查一下,果不其然:
还真的冲突了哟喂……于是删掉struts包中的那个javassist-3.11.0.GA.jar即可,Hibernate这边没错了,可以正常拿出商品信息了。然后我联想到了2天前struts2转json的问题,于是回去将EAGER改回LAZY,问题也没了,也能正常转json了,郁闷,还真是jar包冲突惹的祸。因为当时根本没有报错,只是前台那边我查不到返回的json数据,只知道没有返回json数据,肯定是后台转json出了问题,根据已有的经验,90%是懒加载的问题,但是没想到是jar包冲突惹的祸。
_____________________________________________________________________________________________________________________________________________________
-----乐于分享,共同进步!