main
gzy 3 months ago
parent 07298bf405
commit 6ec58f694e

@ -6,7 +6,7 @@ export function login(username, password, captchaCode, uuid) {
let newPassword = encrypt(password) let newPassword = encrypt(password)
const data = { const data = {
username, username,
newPassword, password:newPassword,
captchaCode, captchaCode,
uuid uuid
} }

@ -18,48 +18,99 @@ const service = axios.create({
timeout: 30000 timeout: 30000
}) })
function stripObjectOfSpecialCharsAndCheck(obj,url) {
if(url == 'backendApi/login/doLogin'){
return true
}
// 定义要检查的特殊字符正则表达式
// const specialCharsRegex = /[<>"'%;()&+]/;
const specialCharsRegex = /[`~!@#$^&*()=|{}':;',\[\].<>/?~@#¥……&*()——|{}【】‘;:”“'。,、?]/
// 检查数组
if (Array.isArray(obj)) {
for (const item of obj) {
// 如果元素是字符串且包含特殊字符
if (typeof item === 'string' && specialCharsRegex.test(item)) {
return false; // 发现特殊字符立即返回false
}
// 如果元素是对象非null则递归检查
if (typeof item === 'object' && item !== null) {
if (!stripObjectOfSpecialCharsAndCheck(item)) {
return false; // 递归调用返回false则当前调用也返回false
}
}
}
// 数组中没有发现特殊字符,继续检查其他类型(尽管在这个函数中不会执行到这里,但为了清晰性)
} else if (typeof obj === 'object' && obj !== null) {
// 检查对象的每个属性
for (const key in obj) {
if (obj.hasOwnProperty(key)) { // 确保属性是对象自身的属性
const value = obj[key];
// 如果值是字符串且包含特殊字符
if (typeof value === 'string' && specialCharsRegex.test(value)) {
return false; // 发现特殊字符立即返回false
}
// 如果值是对象非null则递归检查
if (typeof value === 'object' && value !== null) {
if (!stripObjectOfSpecialCharsAndCheck(value)) {
return false; // 递归调用返回false则当前调用也返回false
}
}
}
}
// 对象中没有发现特殊字符
}
// 如果没有发现特殊字符包括所有嵌套的对象和数组则返回true
return true;
}
// request拦截器 // request拦截器
service.interceptors.request.use(config => { service.interceptors.request.use(config => {
// 是否需要防止数据重复提交 let isHave = stripObjectOfSpecialCharsAndCheck(config.data,config.url)
const isRepeatSubmit = (config.headers || {}).repeatSubmit === false if(!isHave){
alert('禁止输入特殊符号')
return
}else{
// 是否需要防止数据重复提交
const isRepeatSubmit = (config.headers || {}).repeatSubmit === false
if (getToken()) { if (getToken()) {
config.headers['Access-Token'] = getToken(); config.headers['Access-Token'] = getToken();
} }
config.headers['platform'] = 'PC'; config.headers['platform'] = 'PC';
// get请求映射params参数 // get请求映射params参数
if (config.method === 'get' && config.params) { if (config.method === 'get' && config.params) {
let url = config.url + '?' + tansParams(config.params); let url = config.url + '?' + tansParams(config.params);
url = url.slice(0, -1); url = url.slice(0, -1);
config.params = {}; config.params = {};
config.url = url; config.url = url;
}
if (!isRepeatSubmit && (config.method === 'post' || config.method === 'put')) {
const requestObj = {
url: config.url,
data: typeof config.data === 'object' ? JSON.stringify(config.data) : config.data,
time: new Date().getTime()
} }
const sessionObj = cache.session.getJSON('sessionObj') if (!isRepeatSubmit && (config.method === 'post' || config.method === 'put')) {
if (sessionObj === undefined || sessionObj === null || sessionObj === '') { const requestObj = {
cache.session.setJSON('sessionObj', requestObj) url: config.url,
} else { data: typeof config.data === 'object' ? JSON.stringify(config.data) : config.data,
const s_url = sessionObj.url; // 请求地址 time: new Date().getTime()
const s_data = sessionObj.data; // 请求数据 }
const s_time = sessionObj.time; // 请求时间 const sessionObj = cache.session.getJSON('sessionObj')
const interval = 1000; // 间隔时间(ms),小于此时间视为重复提交 if (sessionObj === undefined || sessionObj === null || sessionObj === '') {
if (s_data === requestObj.data && requestObj.time - s_time < interval && s_url === requestObj.url) {
const message = '数据正在处理,请耐心等待';
console.warn(`[${s_url}]: ` + message)
return Promise.reject(new Error(message))
} else {
cache.session.setJSON('sessionObj', requestObj) cache.session.setJSON('sessionObj', requestObj)
} else {
const s_url = sessionObj.url; // 请求地址
const s_data = sessionObj.data; // 请求数据
const s_time = sessionObj.time; // 请求时间
const interval = 1000; // 间隔时间(ms),小于此时间视为重复提交
if (s_data === requestObj.data && requestObj.time - s_time < interval && s_url === requestObj.url) {
const message = '数据正在处理,请耐心等待';
console.warn(`[${s_url}]: ` + message)
return Promise.reject(new Error(message))
} else {
cache.session.setJSON('sessionObj', requestObj)
}
} }
} }
return config
} }
return config
}, error => { }, error => {
console.log(error) console.log(error)
Promise.reject(error) Promise.reject(error)

@ -83,8 +83,8 @@ export default {
codeUrl: "", codeUrl: "",
systemName : process.env.VUE_APP_TITLE, systemName : process.env.VUE_APP_TITLE,
loginForm: { loginForm: {
username: "fuint", username: "",
password: "123456", password: "",
rememberMe: false, rememberMe: false,
captchaCode: "", captchaCode: "",
uuid: "" uuid: ""

Loading…
Cancel
Save