Spring Security缓存的应用之登陆后跳转到登录前源地址
什么意思?
从第3步,我们可以知道,用户的请求被中断了。
用户登录成功后(第7步),会被重定向到origin url,spring security通过使用缓存的请求,使得被中断的请求能够继续执行。
具体请看 探究Spring Security缓存请求
我这里仅讲解如何在ajax登陆后跳转到登录前的链接。
1. 首先,如果想跳转到登陆之前的链接,我们需要拿到缓存:
SavedRequest savedRequest = requestCache.getRequest(request, response);
注意!若用户是直接访问没有权限限制的登陆页面,是不会有缓存的,也就是说savedRequest = null ,所以在使用缓存之前,我们需要做一个非null判断,也就是:
if (savedRequest != null) { // 逻辑代码 }
2. 取到登录前访问的url
String url = savedRequest.getRedirectUrl();
3. 使用hashMap建立一个对象,这是为了后续向浏览器返回json数据
Map json = new HashMap<String, Object>(); json.put("code", 0); json.put("message", "操作成功"); json.put("url", url);
可以看到这个json 对象比较简单,其中url属性是为了让浏览器端的js跳转的
4.设置响应体编码和格式
response.setContentType(FebsConstant.JSON_UTF8);
5.向浏览器进行响应数据,这里的数据是json格式,是使用jackson工具包完成的,Maven地址: JacksonMaven地址
response.getWriter().write(mapper.writeValueAsString(ResponseBo.ok(messsage, url)));
下面是完整的Java代码:
@Override public void onAuthenticationSuccess(HttpServletRequest request, HttpServletResponse response, Authentication authentication) throws IOException, ServletException { // 不管请求哪个页面,登陆成功后仅打开指定页面index// redirectStrategy.sendRedirect(request, response, "/index"); // 获取缓存 SavedRequest savedRequest = requestCache.getRequest(request, response); // 设置响应格式和编码 response.setContentType(FebsConstant.JSON_UTF8); // 缓存非空判断 if (savedRequest != null) { // 跳转到之前引发跳转的url String url = savedRequest.getRedirectUrl(); String messsage = "成功"; // 准备json Map json = new HashMap<String, Object>(); json.put("code", 0); json.put("message", "操作成功"); json.put("url", url); Object jsons = ResponseBo.ok(messsage, url); response.getWriter().write(mapper.writeValueAsString(ResponseBo.ok(messsage, url))); } else { // 这个是没有缓存,直接跳转到默认ajax默认的页面 response.getWriter().write(mapper.writeValueAsString(ResponseBo.ok())); } }
新闻热点
疑难解答
图片精选