Struts2: INfinite recursion detected

在Struts2中遇到一个无限递归的问题,原因是认证授权拦截器导致Action的无限循环调用。当拦截器跳转到noLoginAction时,由于配置问题,请求再次进入拦截器,形成递归。解决办法是在noLoginAction配置中使用默认的拦截器defaultStack,而不是默认的认证授权拦截器,从而避免递归。
摘要由CSDN通过智能技术生成

今天遇到一问题纠缠很久
环境:
    1.写了一个关于身份认证以及授权的拦截器
    2.如果没有通过认证和授权那么将根据客户端的类型返回信息,我开发的系统有两种客户端[浏览器和手机客户端,手机客户端的数据服务器采用Json格式数据进行响应]。
    3.拦截器认证授权失败返回一个全局结果nologin,代码如下:
    身份认证和授权配置:
   
<interceptors>
<interceptor name="authenticationInterceptor" class="com.defshare.crm.web.interceptor.AuthenticationInterceptor" />
<!-- 自定义拦截器需要和缺省拦截器栈整合,否则可能丢失struts2的一些既定功能,比如参数赋值-->
<interceptor-stack name="authenInterceptStack">
<interceptor-ref name="defaultStack"></interceptor-ref>
<interceptor-ref name="authenticationInterceptor"></interceptor-ref>
</interceptor-stack>
</interceptors>

<!--Action的缺省拦截器[身份认证和授权] -->
<default-interceptor-ref name="authenticationInterceptor" />


    拦截器:
   
@Override
public String intercept(ActionInvocation invocation) throws Exception {

//获得当前请求的uri
String uri = ServletActionContext.getRequest().getRequestURI();
uri = uri.substring(ServletActionContext.getRequest().getContextPath().length());
if(log.isInfoEnabled())
log.info("\t当前请求uri:"+uri);

//判断当前uri是否在放行列表存在,存在则放行[最好将此放入配置]
if (permissonURIS.contains(uri.toUpperCase()))
return invocation.invoke();


//初始化需要认证和授权的Uri集合
if (checkURIS.size()==0){
 Object action = invocation.getAction();
 if (action instanceof BaseAction){
 BaseAction baction = (BaseAction)action;
 List<String> smlist = baction.getModules();
 checkURIS.addAll(smlist); 
 }
}

### 回答1: 这是一个异常信息,通常出现在使用Spring框架进行Web开发时,使用JSON作为数据交换格式时出现的。其中,httpmessagenotwritableexception表示该异常是由于尝试向输出消息中写入JSON对象时出错;could not write json表示无法写入JSON对象;infinite recursion则表示出现了无限递归的情况。 问题出现的原因通常是对象之间存在循环依赖关系,导致在序列化为JSON字符串时出现了不断重复的嵌套,最终导致栈溢出。解决此问题的方法一般有两种: 1. 使用@JsonIgnore等注解将循环依赖的字段排除,使其不参与序列化,从而避免无限递归。 2. 在对象之间建立一条非递归的关联关系进行序列化,例如通过将关联关系转化为ID或者通过DTO等中间对象进行转换。 通过采用上述方法,可以解决这个问题,避免出现循环依赖导致的无限递归异常。 ### 回答2: 该异常通常是由于对象之间的循环引用而导致的。在Java对象转换成JSON格式时,如果对象之间存在循环引用,则会出现无限递归的问题,从而导致该异常的发生。 循环引用是指一个对象中包含了另一个对象的引用,而被引用的对象又包含了指向原始对象的引用。当这种关系出现在相互引用的两个对象之间时,就会出现无限递归的问题。 在处理Java对象时,循环引用通常会出现在多对多关系、父子关系或者递归结构等情况下。为了避免这种问题,可以通过修改Java对象中的属性,使用Jackson JSON库的@JsonBackReference和@JsonManagedReference注解或者手动编写JSON序列化程序等方式来解决循环引用的问题。 此外,还可以通过开启Jackson的特殊功能来解决循环引用问题。可以使用@JsonIdentityInfo注解来配置Jackson,使其在序列化对象时使用唯一标识符而不是实际的对象引用。这样,如果存在循环引用,Jackson就会通过唯一标识符来区分不同的对象,并正确地序列化它们,从而避免了无限递归的问题。 总之,在Java对象转换成JSON格式时,要注意对象之间的循环引用问题,避免出现无限递归的情况。可以通过上述方法来解决循环引用问题,确保程序正确运行。 ### 回答3: 这个错误信息是Java程序中使用到JSON序列化的时候可能会遇到的一种问题。如果一个类中有另一个类的实例作为成员变量,并且这两个类相互引用,那么当进行JSON序列化时就会产生无限递归的情况,也就是说序列化一直没有结束而导致程序崩溃。 这种问题的解决方法有多种,一种比较直接的方法是在实体类中添加一个transient关键字来声明某个成员变量不参与序列化,这样就能避免遇到无限递归的情况。但是这种方法只适用于那些不需要进行序列化的成员变量,不适用于需要序列化的情况。 另一种比较常见的解决方法是使用注解@JsonManagedReference和@JsonBackReference。@JsonManagedReference用于标记属性,表示这个属性是可能会被序列化的,而@JsonBackReference则用于标记反向的属性,表示这个属性已经在前面的@JsonManagedReference中序列化完毕了,不需要再次序列化。 总之,解决这个错误要避免成员变量之间相互引用的情况,或者通过标记注解来明确标记序列化的属性,从而避免无限递归导致的错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值