English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Переход на страницу входа при срабатывании сессии webix + springmvc

Введение

Недавно при работе над проектом я обнаружил, что ajax-запросы не могут быть напрямую перенаправлены на страницу登录а на сервере. Проверив некоторые материалы, я нашел метод для jquery-запросов. Однако ajax-запросы webix имеют некоторые отличия от jquery. В этом примере я模仿ю способ обработки jquery для реализации перенаправления на страницу login при сессии webix.

Конкретные действия:

1. Проверив исходный код webix.js,我发现webix.ajax имеет только监听 функции перед запросом "onBeforeAjax". Чтобы получить статус возврата и перезагрузить страницу登录а, необходима функция возврата, но в исходном коде её нет. Поэтому я внес некоторые изменения в исходный код и добавил функцию возврата "onAfterAjax".

Часть с красной маркировкой - это добавленный мной код. При обнаружении завершения ajax, автоматически выполняется "onAfterAjax". (Местоположение кода можно найти в файле webix.js, по условию "onBeforeAjax", и добавить красный код в соответствующее место.

if (webix.callEvent("onBeforeAjax", [s, t, e, a, o, null, r])) {
var h = !1;
if ("GET" !== s) {
var l = !1;
for (var c in o)"content-type" == c.toString().toLowerCase() && (l = !0, "application/json" == o[c] && (h = !0));
l || (o["Content-Type"] = "application/x-www-form-urlencoded")
}
if ("object" == typeof e)if (h)e = this.stringify(e); else {
var u = [];
for (var d in e) {
var f = e[d];
(null === f || f === webix.undefined) && (f = ""), "object" == typeof f && (f = this.stringify(f)), u.push(d + "=" + encodeURIComponent(f))
}
e = u.join("&")
}
e && "GET" === s && (t = t + (-1 != t.indexOf("?") ? "&" : "?") + e,
e = null), a.open(s, t, !this.H);
var b = this.Tw;
b && (a.responseType = b);
for (var c in o)a.setRequestHeader(c, o[c]);
var x = this;
return this.master = this.master || n, a.onreadystatechange = function () {
if (!a.readyState || 4 == a.readyState) {
if (webix.callEvent("onAfterAjax", [a]) === !1) {
return false;
};
if (webix.ajax.count++, i && x && !a.aborted) {
if (-1 != webix.ly.find(a))return webix.ly.remove(a);
var t, e, s = x.master || x, r = a.status >= 400 || 0 === a.status;
"blob" == a.responseType || "arraybuffer" == a.responseType ? (t = "", e = a.response) : (t = a.responseText || "", e = x.J(a)), webix.ajax.$callback(s, i, t, e, a, r)
}
x && (x.master = null), i = x = n = null
}
}, this.qh && (a.timeout = this.qh), this.H ? a.send(e || null) : setTimeout(function () {
a.aborted || (-1 != webix.ly.find(a) ? webix.ly.remove(a) : a.send(e || null));
}, 1), this.master && this.master.Ve && this.master.Ve.push(a), this.H ? a : r
}

2、webix.ajx请求没有明显的标志,jquery.ajax的标识是x-requested-with ,所以我模拟给了个标识requestFlag="webix"(可以自己设置个喜欢的),用"onBeforeAjax"设置

webix.attachEvent("onBeforeAjax",function(s, t, e, a, o){o["requestFlag"]="webix"});

3、监听返回状态

webix.attachEvent("onAfterAjax",function(xhr){if(xhr.getResponseHeader("sessionstatus")=='timeout'){window.location.href='/webix/login.html'}});

4、Код backstage

4.1 Код拦截ора

package com.ljx.filter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
public class UserInterceptor implements HandlerInterceptor {
@Override
public void afterCompletion(HttpServletRequest arg0,
HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception {
}
@Override
public void postHandle(HttpServletRequest arg0,
HttpServletResponse response, Object arg2, ModelAndView arg3)
throws Exception {
response.sendRedirect("/webix/login.html");
}
@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler) throws Exception {
Object obj = request.getSession().getAttribute("LOGIN");
if (null == obj) { // не авторизован
if (request.getHeader("requestFlag") != null
&& запрос.getHeader("requestFlag").equalsIgnoreCase(
"webix")) { // Если это запрос AJAX, заголовок ответа будет содержать requestFlag
response.setHeader("sessionstatus", "timeout");// Установите состояние сессии в заголовке ответа
} else {
response.sendRedirect(request.getContextPath() + "/login");
}
return false;
}
return true;
}
}

4.2 Добавьте конфигурацию拦截器 в файл конфигурации spring

<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/mvc/*" />
<bean class="com.ljx.filter.UserInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>

4.3 Выполните webix.ajax в консоли F12, чтобы проверить эффект

webix.ajax().get("/webix/mvc/login.action")

Названное выше - это介绍 webix+springmvc session timeout redirect login page, которую редактор предлагает вам. Если у вас есть какие-либо вопросы, пожалуйста, оставьте сообщение, редактор своевременно ответит вам.

Заявление: содержимое статьи предоставлено из Интернета, авторские права принадлежат соответствующему автору. Контент предоставлен пользователями Интернета в добровольном порядке и загружен самостоятельно. Веб-сайт не обладает правами собственности и не производит ручную редактуру, не несет ответственности за соответствующие юридические вопросы. Если вы обнаружите содержимое,涉嫌侵犯版权, пожалуйста, отправьте письмо по адресу: notice#oldtoolbag.com (во время отправки письма, пожалуйста, замените # на @) для отчета и предоставьте соответствующие доказательства. Если подтвердится, сайт незамедлительно удалит涉嫌侵权的内容。

Основной курс
Рекомендуем к просмотру