zoukankan      html  css  js  c++  java
  • spring security jquery ajax重定向问题解决

    服务器端security增加一个配置如下:

    @Override
        protected void configure(HttpSecurity http) throws Exception {
            String loginPage = "/login";
            http
                .exceptionHandling()
                .authenticationEntryPoint(new AjaxAuthenticationEntryPoint(loginPage))
                .and()
                .addFilterBefore(new LocaleFilter(localeResolver), UsernamePasswordAuthenticationFilter.class)
        ...
    }
    import java.io.IOException;
    
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    import org.springframework.security.core.AuthenticationException;
    import org.springframework.security.web.authentication.LoginUrlAuthenticationEntryPoint;
    
    import com.zhqn.sc.utils.CommonsUtils;
    
    public class AjaxAuthenticationEntryPoint extends LoginUrlAuthenticationEntryPoint{
    
        public AjaxAuthenticationEntryPoint(String loginFormUrl) {
            super(loginFormUrl);
        }
    
        @Override
        public void commence(HttpServletRequest request, HttpServletResponse response,
                AuthenticationException authException) throws IOException, ServletException {
            if (CommonsUtils.isAjax(request)) {
                String redirectUrl = buildRedirectUrlToLoginPage(request, response, authException);
                response.setHeader("redirectUrl", redirectUrl);
                response.sendError(HttpServletResponse.SC_FORBIDDEN);
            }else {
                super.commence(request, response, authException);
            }
        }
    }

    客服端js设置:

      

      $(document).ajaxError(function(event,xhr,options,exc){
            if(xhr.status == 403 && xhr.getResponseHeader("redirectUrl")) {
                window.top.location.href = xhr.getResponseHeader("redirectUrl");
            }
        });
  • 相关阅读:
    C# DES加密和解密
    SQL设计技巧优化
    MS15-034漏洞技术研究
    Vustudy靶场环境快速搭建
    FastJson<=1.2.47漏洞复现
    多台电脑共享一套鼠键--Mouse Without Borders
    {Java初级系列四}---继承、接口和抽象类
    {Java初级系列三}---面向对象和类
    {Java初级系列二}---Java类基础知识
    {Java初阶系列一}---Java基本简介
  • 原文地址:https://www.cnblogs.com/zhouquan-1992-04-06/p/11512866.html
Copyright © 2011-2022 走看看