首页 > 代码库 > 在struts2的Action、Service中慎起get打头的方法

在struts2的Action、Service中慎起get打头的方法


    由于之前合并了流程及表单分类,在高级查询和流程管理页面打开z-tree树时,前端页面报出queryAllCategory()的空指针异常(逐步调试后在该方法中无空指针异常),并报如下错误:

[16/06/14 07:30:07:007 CST] DEBUG sql.Connection: xxx Connection Closed

org.codehaus.jackson.map.JsonMappingException: No serializer found for class org.apache.ibatis.transaction.managed.ManagedTransactionFactory and no properties discovered to create BeanSerializer (to avoid exception, disable SerializationConfig.Feature.FAIL_ON_EMPTY_BEANS) ) (through reference chain: $Proxy189["targetSource"]->org.springframework.aop.target.SingletonTargetSource["target"]->com.fx.oa.module.bpm.workflow.server.service.impl.ProcessDefineService["orgDao"]->com.fx.oa.module.com.dependence.server.dao.impl.OrgDao["sqlSession"]->org.mybatis.spring.SqlSessionTemplate["sqlSessionFactory"]->org.apache.ibatis.session.defaults.DefaultSqlSessionFactory["configuration"]->org.apache.ibatis.session.Configuration["environment"]->org.apache.ibatis.mapping.Environment["transactionFactory"])

异常分析:

1.同样使用z-tree展示,新建任务页面没有出现异常,可以将流程分类展示出来;

2.高级查询和流程管理页面均有如上问题;

解决思路:

1.怀疑代码错误,先检查流程管理提交的代码,发现没有修改或修改不影响该功能;

2.根据以下关键字org.codehaus.jackson.map.JsonMappingException: No serializer found for class org.apache.ibatis.transaction.managed查询到可能与复杂json对象(包括一对多属性,分类使用的树结构,包括孩子属性List<CategoryEntity>)解析有关,链接1:http://redsky008.iteye.com/blog/1345279,链接2:http://chembo.iteye.com/blog/899703,按照链接所示方法即为复杂json对象@JsonIgnore注解,该方法对此bug无效;

3.新建工作(NT)与流程管理(BM)、高级查询(SQ)的树展示方式相似,将NT的实现copy到BM和SQ,发现可以展示分类,但分类下未展示流程结点:三者展示方式相似,但并不完全相同,NT将后台查询的分类及结点只展示了分类,其他两个展示到叶子结点;

4.NT使用了表单下的分类查询(包括叶子)(/dymcform/queryAllCategory),BM、SQ使用的流程下的分类查询(包括叶子)(/workflow/queryAllCategory),合并后两者实现完全相同,但action不同,一个是表单下的dymcformAction,一个是流程下的flowDesignAction;更换后不再报异常,但并未达到展示叶子的效果;

5.仔细分析异常,发现报出ProcessDefineService下的orgDao错误,观察后发现flowDesignAction下的processDefineServiceget方法,ProcessDefineService下的orgDao也有get方法,这在struts2、Spring中是不被推荐的,原因是Spring在action对service做了IOC,在service又对dao做了IOC,如果在action层又有service的getter或service层又有dao的getter方法,会出现每次action调用结束,会继续调用get**Service方法,继而会调用该service的get**DAO方法,从而产生了上述错误。

6.将action中对service,service中对dao的getter方法去掉,bug解决。


本文出自 “南湖矿工技术空间” 博客,请务必保留此出处http://jncumter.blog.51cto.com/812546/1427243