今天做了一个原以为很简单的异步查询功能,结果折腾了很久才发现问题,这里做一下记录。
公司的后管平台,前端框架采用的struts2,要修改点功能,其中涉及到一个异步请求。
问题如下:
js发起ajax异步请求到后端,后台将一个List集合以JSON形式响应,断点跟代码后台一切正常,但是响应到前端时直接返回了定义好error页面。即下图中映射的error.jsp
并且后台也没有任何错误日志。
既然后台逻辑没有错,且前端正常接收到了数据,那么只能把问题定位在响应JSON时可能出问题了,于是在struts.xml中定义了异常映射配置如下:
<global-results>
<result name="error" >/WEB-INF/content/base/error.jsp</result>
<result name="noAuth" >/WEB-INF/content/base/noAuth.jsp</result>
<result name="exception" >/WEB-INF/content/base/exception.jsp</result>
<result name="login" >/index.jsp</result>
</global-results>
<global-exception-mappings>
<exception-mapping result="exception" exception="java.lang.Exception"></exception-mapping>
</global-exception-mappings>
且在exception.jsp中输出${exception.message}查看异常信息。
果然,异常信息输出表示JAVABEAN中存在懒加载异常,即某个字段有多对一的映射关系,导致在转json的时候会出现无限迭代问题。如图:
到这里问题可以锁定问题了。解决这个问题有很多种解决方案,可以参考:
https://blog.csdn.net/weixin_39910092/article/details/78187010
这里考虑为了不影响其它功能,尽量避免对实体、配置做修改。
这里用includeProperties参数对JSON响应的数据做了过滤,只响应需要用到的字段即可:
results = {
@Result(name = SUCCESS, type = "json",
params={"includeProperties","custinfos\\[\\d+\\]\\.custid,custinfos\\[\\d+\\]\\.custname"
}
修改完重启服务,问题至此解决。