今天遇到一问题纠缠很久
环境:
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);
}
}
Struts2: INfinite recursion detected
最新推荐文章于 2024-06-29 17:34:57 发布
在Struts2中遇到一个无限递归的问题,原因是认证授权拦截器导致Action的无限循环调用。当拦截器跳转到noLoginAction时,由于配置问题,请求再次进入拦截器,形成递归。解决办法是在noLoginAction配置中使用默认的拦截器defaultStack,而不是默认的认证授权拦截器,从而避免递归。
摘要由CSDN通过智能技术生成