spring security插件--获取 登录前被拦截的URL

在Spring Security中,当未登录用户尝试访问受保护的URL时会被拦截。本文探讨如何在登录前获取被拦截的URL,以便登录成功后进行跳转。通过将URL保存到session并在登录后取出,或者在Ajax请求中使用自定义的AuthenticationEntryPoint来构建并获取返回URL。
在web项目中,登录某些页面 需要登录权限,有些是由插件拦截,有的是自己手动写的判断代码
spring securrity中,会有映射的权限访问URL,如果在没有登录情况下 访问这些URL会被插件拦截器自动拦截,那么怎样获取当前被拦截的URL,用来实现跳转?
1.一般实现  登录前的跳转---将登录前访问的URL放入session,登录成功后取出该URL,再删除改属性
     
request.getHeader("referer")//获取登录访问前的URL


2.如果是spring security等安全插件拦截的URL,该如何获取被拦截的URL?

-----这里以AJAX请求登录为例
public class AjaxAwareAuthenticationEntryPoint extends LoginUrlAuthenticationEntryPoint {

	private String ajaxLoginFormUrl;

	@Override
	protected String determineUrlToUseForThisRequest(final HttpServletRequest request,
			final HttpServletResponse response, final AuthenticationException e) {

		if (ajaxLoginFormUrl != null && SpringSecurityUtils.isAjax(request)) {
			return ajaxLoginFormUrl;
		}
        try{
            //设置  session属性--登录成功后要 要跳转的URL
            request.getSession().setAttribute("back",buildHttpReturnUrlForRequest(request));
        }catch(Exception ex){

        }

		return getLoginFormUrl();
	}
    //获取 当前被 (登录前)被拦截的URL
    protected String buildHttpReturnUrlForRequest(HttpServletRequest request)
            throws IOException, ServletException {
        RedirectUrlBuilder urlBuilder = new RedirectUrlBuilder();
        urlBuilder.setScheme("http");
        urlBuilder.setServerName(request.getServerName());
        urlBuilder.setPort(request.getServerPort());
        urlBuilder.setContextPath(request.getContextPath());
        urlBuilder.setServletPath(request.getServletPath());
        urlBuilder.setPathInfo(request.getPathInfo());
        urlBuilder.setQuery(request.getQueryString());

        return urlBuilder.getUrl();
    }
    /**
	 * Dependency injection for the Ajax login form url, e.g. '/login/authAjax'.
	 * @param url  the url
	 */
	public void setAjaxLoginFormUrl(final String url) {
		Assert.isTrue(url == null || url.startsWith("/"), "ajaxLoginFormUrl must begin with '/'");
		ajaxLoginFormUrl = url;
	}
}


评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值