在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解决。


     本文转自 gaochaojs 51CTO博客,原文链接http://blog.51cto.com/jncumter/1427243:,如需转载请自行联系原作者



版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章