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 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀