weixin_33712881 2015-05-20 08:37 采纳率: 0%
浏览 92

没有重定向的Shiro过滤器

I have a REST-Interface that gets called from the Front-End code via jquery-Ajax-Requests. The called url is secured with the following shiro.ini:

/api/** = authc

If the user is not authenticated Shiro wants to redirect to the login-Url and the ajax-Request can't handle that. I'd prefer a HTML status code as answer. What's the best way to achieve this? Thanks for any answers!

  • 写回答

2条回答 默认 最新

  • weixin_33736048 2015-05-20 09:00
    关注

    You need to implement a custom shiro filter. Something like this:

            import javax.servlet.ServletRequest;
            import javax.servlet.ServletResponse;
    
            import java.io.IOException ;
            import javax.servlet.http.HttpServletResponse ;
    
            import org.apache.shiro.web.filter.authz.AuthorizationFilter ;
            import org.apache.shiro.web.util.WebUtils ;
    
            public class LocalhostFilter extends AuthorizationFilter {
    
                private static final String message = "Access denied.";
    
                @Override
                protected boolean isAccessAllowed(ServletRequest request, ServletResponse response, Object mappedValue) throws Exception {
                    //do something when access allowed
                    return true;       
     }
    
                @Override
                protected boolean onAccessDenied(ServletRequest request, ServletResponse response) throws IOException {
                    HttpServletResponse httpResponse ;
                    try { httpResponse = WebUtils.toHttp(response); }
                    catch (ClassCastException ex) { 
                        // Not a HTTP Servlet operation
                        return super.onAccessDenied(request, response) ;
                    }
                    if ( message == null )
                        httpResponse.sendError(403) ;
                    else
                        httpResponse.sendError(403, message) ;
                    return false ;  // No further processing.
                }
            }
    
    评论

报告相同问题?

悬赏问题

  • ¥15 Pwm双极模式H桥驱动控制电机
  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题