refactor: 后台重启过后,前端操作页面弹框提示重新登录

This commit is contained in:
Captain.B 2021-07-01 11:43:42 +08:00 committed by 刘瑞斌
parent 9470cec489
commit 0b21fc8e6a
5 changed files with 19 additions and 11 deletions

View File

@ -2,4 +2,6 @@ package io.metersphere.commons.constants;
public class SessionConstants { public class SessionConstants {
public static final String ATTR_USER = "user"; public static final String ATTR_USER = "user";
public static final String AUTHENTICATION_STATUS = "Authentication-Status";
public static final String AUTHENTICATION_INVALID = "invalid";
} }

View File

@ -1,10 +1,13 @@
package io.metersphere.controller; package io.metersphere.controller;
import io.metersphere.commons.constants.SessionConstants;
import io.metersphere.commons.utils.SessionUtils; import io.metersphere.commons.utils.SessionUtils;
import org.springframework.stereotype.Controller; import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMapping;
import javax.servlet.http.HttpServletResponse;
@Controller @Controller
@RequestMapping @RequestMapping
public class IndexController { public class IndexController {
@ -15,8 +18,9 @@ public class IndexController {
} }
@GetMapping(value = "/login") @GetMapping(value = "/login")
public String login() { public String login(HttpServletResponse response) {
if (SessionUtils.getUser() == null) { if (SessionUtils.getUser() == null) {
response.setHeader(SessionConstants.AUTHENTICATION_STATUS, SessionConstants.AUTHENTICATION_INVALID);
return "login.html"; return "login.html";
} else { } else {
return "redirect:/"; return "redirect:/";

View File

@ -1,5 +1,6 @@
package io.metersphere.security; package io.metersphere.security;
import io.metersphere.commons.constants.SessionConstants;
import io.metersphere.commons.utils.LogUtil; import io.metersphere.commons.utils.LogUtil;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.apache.shiro.SecurityUtils; import org.apache.shiro.SecurityUtils;
@ -31,7 +32,7 @@ public class ApiKeyFilter extends AnonymousFilter {
} }
if (!SecurityUtils.getSubject().isAuthenticated()) { if (!SecurityUtils.getSubject().isAuthenticated()) {
((HttpServletResponse) response).setHeader("Authentication-Status", "invalid"); ((HttpServletResponse) response).setHeader(SessionConstants.AUTHENTICATION_STATUS, SessionConstants.AUTHENTICATION_INVALID);
} }
} catch (Exception e) { } catch (Exception e) {
if (ApiKeyHandler.isApiKeyCall(WebUtils.toHttp(request))) { if (ApiKeyHandler.isApiKeyCall(WebUtils.toHttp(request))) {

View File

@ -1,5 +1,6 @@
package io.metersphere.security; package io.metersphere.security;
import io.metersphere.commons.constants.SessionConstants;
import io.metersphere.commons.user.SessionUser; import io.metersphere.commons.user.SessionUser;
import io.metersphere.commons.utils.CodingUtil; import io.metersphere.commons.utils.CodingUtil;
import io.metersphere.commons.utils.CommonBeanFactory; import io.metersphere.commons.utils.CommonBeanFactory;
@ -25,7 +26,7 @@ public class CsrfFilter extends AnonymousFilter {
HttpServletRequest httpServletRequest = WebUtils.toHttp(request); HttpServletRequest httpServletRequest = WebUtils.toHttp(request);
if (!SecurityUtils.getSubject().isAuthenticated()) { if (!SecurityUtils.getSubject().isAuthenticated()) {
((HttpServletResponse) response).setHeader("Authentication-Status", "invalid"); ((HttpServletResponse) response).setHeader(SessionConstants.AUTHENTICATION_STATUS, SessionConstants.AUTHENTICATION_INVALID);
return true; return true;
} }
// api 过来的请求 // api 过来的请求

View File

@ -1,6 +1,6 @@
import {Message, MessageBox} from 'element-ui'; import {Message, MessageBox} from 'element-ui';
import axios from "axios"; import axios from "axios";
import i18n from '../../i18n/i18n' import i18n from '../../i18n/i18n';
import {TokenKey} from "@/common/js/constants"; import {TokenKey} from "@/common/js/constants";
export function registerRequestHeaders() { export function registerRequestHeaders() {
@ -33,7 +33,7 @@ export function login() {
callback: () => { callback: () => {
axios.get("/signout"); axios.get("/signout");
localStorage.setItem('Admin-Token', "{}"); localStorage.setItem('Admin-Token', "{}");
window.location.href = "/login" window.location.href = "/login";
} }
}); });
} }
@ -139,7 +139,7 @@ export function fileUpload(url, file, files, param, success, failure) {
if (files) { if (files) {
files.forEach(f => { files.forEach(f => {
formData.append("files", f); formData.append("files", f);
}) });
} }
formData.append('request', new Blob([JSON.stringify(param)], {type: "application/json"})); formData.append('request', new Blob([JSON.stringify(param)], {type: "application/json"}));
let axiosRequestConfig = getUploadConfig(url, formData); let axiosRequestConfig = getUploadConfig(url, formData);
@ -156,15 +156,15 @@ export default {
if (!axios) { if (!axios) {
window.console.error('You have to install axios'); window.console.error('You have to install axios');
return return;
} }
if (!Message) { if (!Message) {
window.console.error('You have to install Message of ElementUI'); window.console.error('You have to install Message of ElementUI');
return return;
} }
let login = login; // let login = login;
axios.defaults.withCredentials = true; axios.defaults.withCredentials = true;
@ -189,4 +189,4 @@ export default {
Vue.prototype.$fileUpload = fileUpload; Vue.prototype.$fileUpload = fileUpload;
} }
} };