From c7aece35a62b6e91fd98a625bf0e53f64bfbd18d Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期四, 17 八月 2023 16:22:15 +0800 Subject: [PATCH] 2023-08-17 --- src/api/index.js | 1158 +++++++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 835 insertions(+), 323 deletions(-) diff --git a/src/api/index.js b/src/api/index.js index d2082ee..abcfa0b 100644 --- a/src/api/index.js +++ b/src/api/index.js @@ -1,64 +1,82 @@ import axios from 'axios' import qs from 'qs' -import {notification } from 'antd' +import { notification, Modal } from 'antd' import md5 from 'md5' +import CryptoJS from 'crypto-js' +import jsSHA from 'jssha' +import moment from 'moment' + import Utils from '@/utils/utils.js' -import options from '@/store/options.js' +import CacheUtils from './cacheutils' + +window.GLOB.IndexDB = null +window.GLOB.OuterToken = {} +window.GLOB.$error = false + +let service = window.GLOB.service ? '-' + window.GLOB.service.replace('/', '') : '' +let db = `mkdb${service}` + +if (window.indexedDB) { + CacheUtils.openIndexDB(db) +} axios.defaults.crossDomain = true axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8' -axios.defaults.withCredentials = true - -axios.interceptors.request.use((config) => { - config.method = 'post' - if (config.url.includes('LoginAndRedirect') || config.url.includes('getjsonresult')) { - config.data = qs.stringify(config.data) - } else if (config.url.includes('Upload') || config.url.includes('doupload') || config.url.includes('dopreload')) { - config.headers = { 'Content-Type': 'multipart/form-data' } - } else { - // config.headers.token = sessionStorage.getItem('TOKEN') || '' - config.data = JSON.stringify(config.data) - } - - return config -}, (error) => { - return Promise.reject(error) -}) - -const setCurrentUrl = () => { - if (!!(window.history && window.history.pushState)) { - sessionStorage.clear() - window.history.replaceState(null, null, window.location.href.split('#')[0] + '#/login') - window.location.reload() - } -} - -window.GLOB.CacheMap = new Map() +axios.defaults.withCredentials = false axios.interceptors.response.use((response) => { if (response.data.ErrCode === 'LoginError') { - setCurrentUrl() + if (window.GLOB.developing) { + sessionStorage.setItem('devError', 'true') + response.data.ErrCode = 'E' + return Promise.resolve(response.data) + } else if (response.config.url.indexOf('https://sso.mk9h.cn/webapi/dostars') > -1) { + return Promise.reject(response.data) + } else if (response.config.url.indexOf('https://epc.mk9h.cn/webapi/dostars') > -1) { + return Promise.reject(response.data) + } + + if (!window.GLOB.$error) { + window.GLOB.$error = true + + Modal.destroyAll() + Modal.error({ + title: response.data.message, + okText: '鐭ラ亾浜�', + onOk: () => { + window.GLOB.$error = false + sessionStorage.clear() + if (!!(window.history && window.history.pushState)) { + window.history.replaceState(null, null, window.location.href.split('#')[0] + '#/login') + window.location.reload() + } + } + }) + } + + return Promise.reject(response.data) } else { return Promise.resolve(response.data) } }, (error) => { - notification.error({ - className: 'notification-custom-error', - bottom: 0, - message: '鐘舵�佺爜-' + error.response.status + '锛岃鑱旂郴绠$悊鍛�', - placement: 'bottomRight', - duration: 15 - }) - return Promise.reject(error) + let response = error.response || '' + + if (response && response.status) { + notification.error({ + className: 'notification-custom-error', + bottom: 0, + message: '鐘舵�佺爜-' + response.status + '锛岃鑱旂郴绠$悊鍛�', + placement: 'bottomRight', + duration: 15 + }) + } + + return Promise.reject(response) }) class Api { constructor() { - if (process.env.NODE_ENV === 'production') { - axios.defaults.baseURL = document.location.origin + '/' + window.GLOB.service - } else { - // axios.defaults.baseURL = 'http://127.0.0.1:8888' - } + axios.defaults.baseURL = window.GLOB.baseurl } /** @@ -66,11 +84,188 @@ * @param {Object} param 鏌ヨ鍙婃彁浜ゅ弬鏁� */ dostarInterface (param) { - param.userid = '' + param.userid = param.userid || '' return axios({ - url: '/webapi/dostar', - data: param + url: `/webapi/dostar${param.func ? '/' + param.func : ''}`, + method: 'post', + data: JSON.stringify(param) + }) + } + + /** + * @description 寰俊涓氬姟璇锋眰 + */ + wxAccessToken (domain = '') { + let _url = window.GLOB.baseurl + 'wxpay/getaccesstoken' + + if (domain) { + _url = domain + 'wxpay/getaccesstoken' + } + + return new Promise(resolve => { + if (window.GLOB.accessToken.domain === domain && window.GLOB.accessToken.accessTime && (parseInt(new Date().getTime() / 1000) - window.GLOB.accessToken.accessTime < 30)) { + resolve(window.GLOB.accessToken) + } else { + window.GLOB.accessToken = {domain} + axios({ + url: _url, + method: 'get' + }).then(res => { + if (res.oa_access_token || res.mini_access_token) { + window.GLOB.accessToken.accessTime = parseInt(new Date().getTime() / 1000) + window.GLOB.accessToken.oa_access_token = res.oa_access_token + window.GLOB.accessToken.mini_access_token = res.mini_access_token + } + resolve(res) + }) + } + }) + } + + /** + * @description 寰俊涓氬姟璇锋眰 + */ + wxNginxRequest (url, method, param) { + let _url = url + + if (!/^http/.test(url)) { + _url = window.GLOB.location + '/' + url + if (process.env.NODE_ENV === 'production') { + _url = document.location.origin + '/' + url + } + if (/^http:\/\/(qingqiumarket.cn|cloud.mk9h.cn|sso.mk9h.cn)/.test(_url)) { + _url = window.GLOB.location + ':8080/' + url + if (process.env.NODE_ENV === 'production') { + _url = document.location.origin + ':8080/' + url + } + } else if (/^https:\/\/(qingqiumarket.cn|cloud.mk9h.cn|sso.mk9h.cn)/.test(_url)) { + _url = window.GLOB.location + ':8443/' + url + if (process.env.NODE_ENV === 'production') { + _url = document.location.origin + ':8443/' + url + } + } + } + + if (param) { + return axios({ + url: _url, + method, + data: param + }) + } + + return axios({ + url: _url, + method + }) + } + + /** + * @description 鐩存帴璇锋眰 + */ + directRequest (params) { + return axios(params) + } + + /** + * @description 娓稿鐧诲綍 + */ + getTouristMsg (binding_type, appid, openid, memberid, scanId) { + let _SessionUid = localStorage.getItem('SessionUid') + + if (!_SessionUid) { // 鎵嬪姩娓呴櫎SessionUid鏃讹紝瀹炴椂鐢熸垚 + _SessionUid = Utils.getuuid() + localStorage.setItem('SessionUid', _SessionUid) + } + + let param = { + func: 's_visitor_login', + timestamp: moment().format('YYYY-MM-DD HH:mm:ss'), + SessionUid: _SessionUid, + TypeCharOne: 'pc', + kei_id: window.btoa(window.encodeURIComponent(window.GLOB.host)), + appkey: window.GLOB.appkey || '' + } + + let url = '/webapi/dologon/s_visitor_login' + if (window.GLOB.mainSystemApi) { + param.rduri = window.GLOB.mainSystemApi.replace(/\/webapi(.*)/, '/webapi/dologon/s_visitor_login') + } + + if (binding_type === 'mk') { + param.binding_type = 'mk' + param.thd_party_member_id = memberid + param.thd_party_openid = openid + param.thd_party_appid = appid + param.id = scanId + } else if (binding_type === 'login_check') { // appid 姝ゆ椂涓虹洰鏍囧湴鍧� + param.v_type = 'login_check' + param.LoginUID = sessionStorage.getItem('LoginUID') || '' + + if (!param.rduri) { + param.rduri = window.GLOB.baseurl + 'webapi/dologon/s_visitor_login' + } + + if (appid) { + url = appid.replace(/\/webapi(.*)/, '/webapi/dologon/s_visitor_login') + param.linkurl = appid.replace(/\/webapi(.*)/, '/index.html') + } else { + param.linkurl = window.GLOB.linkurl + } + } + + param.LText = md5(window.btoa(_SessionUid + param.timestamp + (param.linkurl || ''))) + + // param.secretkey = md5(param.LText + 'mingke' + param.timestamp) // v_type 涓虹┖鏃� + let solt = md5((window.GLOB.appkey + window.btoa(window.GLOB.appkey + 'mingke') + 'mingke').toLowerCase()).slice(-6).toUpperCase() + + param.v_type = param.v_type || 'Y' + param.secretkey = md5(param.LText + solt + param.timestamp) + + return axios({ + url: url, + method: 'post', + data: JSON.stringify(param) + }) + } + + /** + * @description 鎵嬫満鍙烽獙璇佺爜鐧诲綍 + */ + getphoneusermsg (phoneNo, checkcode, isCloud = false) { + let param = { + // func: 'webapi_login', + mob: phoneNo, + UserName: '', + Password: '', + check_code: checkcode, + way_no: 'sms_vcode', + systemType: window.GLOB.sysType, + login_city: sessionStorage.getItem('city') || '', + login_id_address: sessionStorage.getItem('ipAddress') || '', + kei_id: window.btoa(window.encodeURIComponent(window.GLOB.host)), + device_id: localStorage.getItem('SessionUid'), + appkey: window.GLOB.appkey || '' + } + + let url = '/webapi/dologon' + if (isCloud) { + param.debug = 'Y' + if (window.GLOB.cloudServiceApi) { + param.rduri = window.GLOB.cloudServiceApi.replace(/\/webapi(.*)/, '/webapi/dologon') + } + } else if (window.GLOB.mainSystemApi) { + if (window.GLOB.sysType !== 'cloud' && window.GLOB.systemType !== 'production') { + param.linkurl = window.GLOB.linkurl + } + param.rduri = window.GLOB.mainSystemApi.replace(/\/webapi(.*)/, '/webapi/dologon') + } + + return axios({ + url, + method: 'post', + data: JSON.stringify(param) }) } @@ -78,73 +273,230 @@ * @description 鐧诲綍绯荤粺, 鑾峰彇鐢ㄦ埛淇℃伅 */ getusermsg (username, password, isCloud = false) { + let shim = +sessionStorage.getItem('sys_time_shim') let param = { // func: 'webapi_login', UserName: username, - Password: password, - systemType: options.sysType, - Type: 'X' + systemType: window.GLOB.sysType, + Type: 'S', + login_city: sessionStorage.getItem('city') || '', + login_id_address: sessionStorage.getItem('ipAddress') || '', + kei_id: window.btoa(window.encodeURIComponent(window.GLOB.host)), + device_id: localStorage.getItem('SessionUid'), + timestamp: moment().add(shim, 'seconds').format('YYYY-MM-DD HH:mm:ss'), + appkey: window.GLOB.appkey || '' } + + // Type: 'S' 鏃� + let shaObj = new jsSHA('SHA-1', 'TEXT') + shaObj.update(password) + param.Password = shaObj.getHash('HEX').toUpperCase() + param.Password = md5(username + param.Password + param.timestamp) - param.Password = Utils.formatOptions(param.Password) - param.appkey = window.GLOB.appkey || '' + // Type: 'mk_' 鏃� + // param.Type = '鍏挜' + // let shaObj = new jsSHA('SHA-1', 'TEXT') + // shaObj.update(password) + // param.Password = shaObj.getHash('HEX').toUpperCase() + // param.Password = md5('绉侀挜' + username + param.Password + param.timestamp) + + // Type: 'X' 鏃� + // param.Password = Utils.formatOptions(password) + + let url = '/webapi/dologon' if (isCloud) { param.debug = 'Y' - if (options.cloudServiceApi) { - param.rduri = options.cloudServiceApi.replace(/\/webapi(.*)/, '/webapi/dologon') + if (window.GLOB.cloudServiceApi) { + param.rduri = window.GLOB.cloudServiceApi.replace(/\/webapi(.*)/, '/webapi/dologon') } - } else if (!isCloud && window.GLOB.mainSystemApi) { + } else if (window.GLOB.mainSystemApi) { + if (window.GLOB.sysType !== 'cloud' && window.GLOB.systemType !== 'production') { + param.linkurl = window.GLOB.linkurl + } param.rduri = window.GLOB.mainSystemApi.replace(/\/webapi(.*)/, '/webapi/dologon') } return axios({ - url: '/webapi/dologon', - data: param + url, + method: 'post', + data: JSON.stringify(param) }) + } + + delCacheConfig (type = '') { + let date = moment().subtract(7, 'days').format('YYYY-MM-DD HH:mm:ss') + CacheUtils.delIndexDBCacheConfig(date, type) + } + + writeCacheConfig (menuid, data) { + if (!menuid) return + let date = moment().format('YYYY-MM-DD HH:mm:ss') + let _data = data ? JSON.stringify(data) : '' + let userid = sessionStorage.getItem('UserID') || '' + + CacheUtils.writeCacheInIndexDB({menuid: md5(menuid + userid), CreateDate: date, LongParam: _data}) + } + + getLCacheConfig (menuid, minutes) { + return new Promise((resolve, reject) => { + let limit = minutes ? moment().subtract(minutes, 'minutes').format('YYYY-MM-DD HH:mm:ss') : '' + let userid = sessionStorage.getItem('UserID') || '' + + CacheUtils.getIndexDBCacheConfig(md5(menuid + userid)).then(res => { + if (res && res.LongParam) { + resolve({data: JSON.parse(res.LongParam), valid: !limit || res.CreateDate > limit}) + } else { + resolve({data: null, valid: false}) + } + }) + }) + } + + /** + * @description 鑾峰彇绯荤粺鐗堟湰淇℃伅 + */ + getAppVersion (reload) { + if (!window.GLOB.IndexDB) { + return Promise.reject() + } + + let shim = +sessionStorage.getItem('sys_time_shim') + let curTime = moment().add(shim, 'seconds').format('YYYY-MM-DD HH:mm:ss') + '.000' + + return new Promise((resolve, reject) => { + CacheUtils.getIndexDBVersion().then(msg => { + let param = { + func: 's_get_app_version', + modifydate: msg.createDate + } + + param.TypeCharOne = '' + param.typename = '' + + if (!msg.createDate && !msg.menuids) { + CacheUtils.updateIndexDBversion({version: '1.00', createDate: curTime}) + resolve() + return + } else if (!msg.createDate || reload === true) { + param.modifydate = curTime + param.menuids = window.btoa(msg.menuids) + } else if (msg.menuids) { + let d = localStorage.getItem(db) + + if (!d || curTime.indexOf(d) === -1) { + param.menuids = window.btoa(msg.menuids) + } + + localStorage.setItem(db, curTime.substr(0, 10)) + } + + this.getSystemConfig(param).then(res => { + if (!res.status) { + reject() + return + } + + let list = res.menu_data || [] + + if (res.menu_del) { + list.push(...res.menu_del) + } + + list = list.map(mid => mid.menuid) + + if (typeof(reload) === 'string' && !list.includes(reload)) { + list.push(reload) + } + + if (list.length > 0) { + let clear = false + let _appkey = window.GLOB.appkey.substr(-10) + let reg = new RegExp(_appkey + '$', 'i') + + list.forEach(mid => { + if (reg.test(mid)) { + clear = true + } + }) + if (clear) { + list = '' + } + CacheUtils.delIndexDBConfig(list) + this.delCacheConfig('all') + } + + CacheUtils.updateIndexDBversion({version: res.app_version || '1.00', createDate: curTime}) + + resolve() + }) + }, () => { + reject() + }) + }) + } + + /** + * @description 鏇存柊绯荤粺鐗堟湰淇℃伅锛屾竻绌洪厤缃俊鎭� + */ + updateAppVersion () { + CacheUtils.delIndexDBConfig() + CacheUtils.updateIndexDBversion() + // CacheUtils.clearFuncs() + } + + /** + * @description 鍒犻櫎鏌愪釜鑿滃崟閰嶇疆淇℃伅 + */ + deleteMenuStorage (menuId) { + CacheUtils.delIndexDBConfig(menuId) } /** * @description 鑾峰彇鎴栦慨鏀逛簯绔厤缃� */ getCloudConfig (param) { - param.lang = localStorage.getItem('lang') || '' - param.appkey = window.GLOB.appkey || '' + param.lang = param.lang || sessionStorage.getItem('lang') || '' + param.appkey = param.appkey || window.GLOB.appkey || '' + param.SessionUid = localStorage.getItem('SessionUid') || '' + param.userid = param.userid || sessionStorage.getItem('CloudUserID') || '' + param.LoginUID = param.LoginUID || sessionStorage.getItem('CloudLoginUID') || '' - if (sessionStorage.getItem('CloudUserID') && options.cloudServiceApi) { // 瀛樺湪浜戠鐧诲綍淇℃伅锛屼笖瀛樺湪浜戠鍦板潃 - param.rduri = options.cloudServiceApi - param.userid = sessionStorage.getItem('CloudUserID') - param.SessionUid = sessionStorage.getItem('CloudSessionUid') || '' - param.LoginUID = sessionStorage.getItem('CloudLoginUID') || '' - } else if (window.GLOB.mainSystemApi) { - param.rduri = window.GLOB.mainSystemApi - param.userid = sessionStorage.getItem('UserID') - param.SessionUid = sessionStorage.getItem('SessionUid') || '' - param.LoginUID = sessionStorage.getItem('LoginUID') || '' - } else { - param.userid = sessionStorage.getItem('UserID') - param.SessionUid = sessionStorage.getItem('SessionUid') || '' - param.LoginUID = sessionStorage.getItem('LoginUID') || '' + param = this.encryptParam(param) + + let url = window.GLOB.cloudServiceApi ? window.GLOB.cloudServiceApi : '/webapi/dostars' + if (param.func) { + url = url + '/' + param.func } - param.nonc = Utils.getuuid() - - let keys = Object.keys(param).sort() - let values = '' - keys.forEach(key => { - if (key === 'rduri' || key === 't') return - if (typeof(param[key]) === 'object') { - values += key + JSON.stringify(param[key]) - } else { - values += key + param[key] - } + return axios({ + url, + method: 'post', + data: JSON.stringify(param) }) - param.sign = md5(values) - param.t = new Date().getTime() + } + + /** + * @description 鑾峰彇鎴栦慨鏀圭郴缁熼厤缃紝澧炲姞appkey + */ + getSystemFuncs (time) { + let param = { + func: 's_get_func_base_sso', + update_date: time, + userid: sessionStorage.getItem('UserID') || '', + lang: sessionStorage.getItem('lang') || '', + SessionUid: localStorage.getItem('SessionUid') || '', + LoginUID: sessionStorage.getItem('LoginUID') || '', + appkey: window.GLOB.appkey + } + + let url = window.GLOB.mainSystemApi || '/webapi/dostars' + param = this.encryptParam(param) return axios({ - url: `/webapi/dostars${param.func ? '/' + param.func : ''}`, - data: param + url: `${url}/${param.func}`, + method: 'post', + data: JSON.stringify(param) }) } @@ -152,71 +504,156 @@ * @description 鑾峰彇鎴栦慨鏀圭郴缁熼厤缃紝澧炲姞appkey */ getSystemConfig (param) { - param.userid = sessionStorage.getItem('UserID') - param.lang = localStorage.getItem('lang') || '' - param.SessionUid = sessionStorage.getItem('SessionUid') || '' - param.LoginUID = sessionStorage.getItem('LoginUID') || '' - param.appkey = window.GLOB.appkey || '' + param.userid = param.userid || sessionStorage.getItem('UserID') || '' + param.lang = param.lang || sessionStorage.getItem('lang') || '' + param.SessionUid = localStorage.getItem('SessionUid') || '' + param.LoginUID = param.LoginUID || sessionStorage.getItem('LoginUID') || '' + param.appkey = param.appkey || window.GLOB.appkey - if (sessionStorage.getItem('isEditState') === 'true' && options.cloudServiceApi) { // 缂栬緫鐘舵�侊紝涓斿瓨鍦ㄤ簯绔湴鍧� - param.rduri = options.cloudServiceApi - param.userid = sessionStorage.getItem('CloudUserID') - param.SessionUid = sessionStorage.getItem('CloudSessionUid') || '' + let url = '/webapi/dostars' + if (window.GLOB.mkHS && window.GLOB.cloudServiceApi) { // HS涓嬶紝涓斿瓨鍦ㄤ簯绔湴鍧� + url = window.GLOB.cloudServiceApi + param.userid = sessionStorage.getItem('CloudUserID') || '' param.LoginUID = sessionStorage.getItem('CloudLoginUID') || '' } else if (window.GLOB.mainSystemApi) { - param.rduri = window.GLOB.mainSystemApi + if (!window.GLOB.transfer) { + url = window.GLOB.mainSystemApi + } else { + param.rduri = window.GLOB.mainSystemApi + } } - param.nonc = Utils.getuuid() - - let keys = Object.keys(param).sort() - let values = '' - keys.forEach(key => { - if (key === 'rduri' || key === 't') return - if (typeof(param[key]) === 'object') { - values += key + JSON.stringify(param[key]) - } else { - values += key + param[key] - } - }) - param.sign = md5(values) - param.t = new Date().getTime() + param = this.encryptParam(param) return axios({ - url: `/webapi/dostars${param.func ? '/' + param.func : ''}`, - data: param + url: `${url}${param.func ? '/' + param.func : ''}`, + method: 'post', + data: JSON.stringify(param) }) } /** - * @description 鑾峰彇鎴栦慨鏀规湰鍦伴厤缃紝澧炲姞appkey + * @description 鑾峰彇绯荤粺閰嶇疆锛屽彇鍊间紭鍏堢瓑绾ndexDB銆佺紦瀛樸�佹湇鍔″櫒 */ - getLocalConfig (param) { - param.userid = sessionStorage.getItem('UserID') - param.lang = localStorage.getItem('lang') || '' - param.SessionUid = sessionStorage.getItem('SessionUid') || '' + getCacheConfig (param) { + param.userid = sessionStorage.getItem('UserID') || '' + param.lang = param.lang || sessionStorage.getItem('lang') || '' + param.SessionUid = localStorage.getItem('SessionUid') || '' + param.LoginUID = sessionStorage.getItem('LoginUID') || '' + param.appkey = param.appkey || window.GLOB.appkey || '' + + let url = '/webapi/dostars' + if (window.GLOB.mkHS) { // HS涓嬶紝鍗曠偣鐧诲綍鏈嶅姟鍣ㄤ负浜戠 + if (window.GLOB.cloudServiceApi) { // 瀛樺湪浜戠鍦板潃鏃讹紝浣跨敤浜戠绯荤粺鍙傛暟 + url = window.GLOB.cloudServiceApi + param.userid = sessionStorage.getItem('CloudUserID') || '' + param.LoginUID = sessionStorage.getItem('CloudLoginUID') || '' + } + } else if (window.GLOB.mainSystemApi) { + if (!window.GLOB.transfer) { + url = window.GLOB.mainSystemApi + } else { + param.rduri = window.GLOB.mainSystemApi + } + } + + let key = md5(param.MenuID + param.userid) + + if (window.GLOB.IndexDB) { + return new Promise(resolve => { + CacheUtils.getIndexDBMenuConfig(key).then(res => { + resolve(res) + }, () => { + param = this.encryptParam(param) + axios({ + url: `${url}${param.func ? '/' + param.func : ''}`, + method: 'post', + data: JSON.stringify(param) + }).then(res => { + if (res.status && window.GLOB.IndexDB) { + let msg = { + ...res, + userid: param.userid, + menuid: param.MenuID, + id: key + } + CacheUtils.writeInIndexDB(msg) + } else if (res.status) { + window.GLOB.CacheMap.set(key, res) + } + resolve(res) + }) + }) + }) + } else if (window.GLOB.CacheMap.has(key)) { + return Promise.resolve(window.GLOB.CacheMap.get(key)) + } else { + param = this.encryptParam(param) + + return new Promise(resolve => { + axios({ + url: `${url}${param.func ? '/' + param.func : ''}`, + method: 'post', + data: JSON.stringify(param) + }).then(res => { + if (res.status) { + window.GLOB.CacheMap.set(key, res) + } + resolve(res) + }) + }) + } + } + + /** + * @description 鑾峰彇鏈湴绯荤粺閰嶇疆 + */ + getLocalCacheConfig (param) { + param.userid = sessionStorage.getItem('UserID') || '' + param.lang = sessionStorage.getItem('lang') || '' + param.SessionUid = localStorage.getItem('SessionUid') || '' param.LoginUID = sessionStorage.getItem('LoginUID') || '' param.appkey = window.GLOB.appkey || '' + let _param = md5(JSON.stringify(param)) + + if (window.GLOB.CacheMap.has(_param)) { + return Promise.resolve(window.GLOB.CacheMap.get(_param)) + } else { + return Promise.resolve({ErrCode: 'S', ErrMesg: '', LongParam: '', message: '', status: false}) + } + } + + /** + * @description dostars 鍙傛暟鍔犲瘑 + */ + encryptParam (param) { param.nonc = Utils.getuuid() - + let keys = Object.keys(param).sort() let values = '' keys.forEach(key => { if (key === 'rduri' || key === 't') return - if (typeof(param[key]) === 'object') { + if (param[key] === undefined) { + delete param[key] + } else if (typeof(param[key]) === 'object') { values += key + JSON.stringify(param[key]) } else { values += key + param[key] } }) - param.sign = md5(values) - param.t = new Date().getTime() + param.sign = md5(values) + param.t = new Date().getTime(); - return axios({ - url: `/webapi/dostars${param.func ? '/' + param.func : ''}`, - data: param + ['arr_field', 'LText_field', 'custom_script', 'LText1', 'LText', 'LText2', 'DateCount'].forEach(key => { + if (param[key]) { + let val = param[key] + delete param[key] + param[key] = val + } }) + + return param } /** @@ -224,52 +661,39 @@ * @param {Object} param 璇锋眰鍙傛暟 * @param {Boolean} SSO 鏄惁涓哄崟鐐圭櫥褰曞湴鍧� */ - getSystemCacheConfig (param, SSO = true) { - param.userid = sessionStorage.getItem('UserID') || '' - param.lang = localStorage.getItem('lang') || '' - param.SessionUid = sessionStorage.getItem('SessionUid') || '' - param.LoginUID = sessionStorage.getItem('LoginUID') || '' + getSystemCacheConfig (param, cache = true) { + param.userid = param.userid || sessionStorage.getItem('UserID') || '' + param.lang = param.lang || sessionStorage.getItem('lang') || '' + param.SessionUid = localStorage.getItem('SessionUid') || '' + param.LoginUID = param.LoginUID || sessionStorage.getItem('LoginUID') || '' param.appkey = window.GLOB.appkey || '' - if (sessionStorage.getItem('isEditState') === 'true' && SSO) { // 缂栬緫鐘舵�侊紝鍗曠偣鐧诲綍鏈嶅姟鍣ㄤ负浜戠 - if (options.cloudServiceApi) { // 瀛樺湪浜戠鍦板潃鏃讹紝浣跨敤浜戠绯荤粺鍙傛暟 - param.rduri = options.cloudServiceApi - param.userid = sessionStorage.getItem('CloudUserID') || '' - param.SessionUid = sessionStorage.getItem('CloudSessionUid') || '' - param.LoginUID = sessionStorage.getItem('CloudLoginUID') || '' - } - } else if (window.GLOB.mainSystemApi && SSO) { - param.rduri = window.GLOB.mainSystemApi + let url = '/webapi/dostars' + if (param.rduri && !window.GLOB.transfer) { + url = param.rduri + delete param.rduri } - let _param = JSON.parse(JSON.stringify(param)) // 缂撳瓨鏍¢獙锛屽幓闄ゆ椂闂村拰鍔犲瘑瀛楃 - delete _param.timestamp - delete _param.secretkey - _param = JSON.stringify(_param) - _param = md5(_param) + let _param = '' + if (cache) { + _param = JSON.parse(JSON.stringify(param)) // 缂撳瓨鏍¢獙锛屽幓闄ゆ椂闂村拰鍔犲瘑瀛楃 + delete _param.timestamp + delete _param.secretkey + delete _param.open_key + _param = JSON.stringify(_param) + _param = md5(_param) + } - if (window.GLOB.CacheMap.has(_param)) { + if (cache && window.GLOB.CacheMap.has(_param)) { return Promise.resolve(window.GLOB.CacheMap.get(_param)) } else { - param.nonc = Utils.getuuid() - - let keys = Object.keys(param).sort() - let values = '' - keys.forEach(key => { - if (key === 'rduri' || key === 't') return - if (typeof(param[key]) === 'object') { - values += key + JSON.stringify(param[key]) - } else { - values += key + param[key] - } - }) - param.sign = md5(values) - param.t = new Date().getTime() + param = this.encryptParam(param) return new Promise(resolve => { axios({ - url: `/webapi/dostars${param.func ? '/' + param.func : ''}`, - data: param + url: `${url}${param.func ? '/' + param.func : ''}`, + method: 'post', + data: JSON.stringify(param) }).then(res => { if (res.status) { window.GLOB.CacheMap.set(_param, res) @@ -280,151 +704,240 @@ } } - /** - * @description 鑾峰彇涓氬姟閫氱敤鎺ュ彛 - */ - genericInterface (param) { - param.userid = sessionStorage.getItem('UserID') - param.lang = localStorage.getItem('lang') || '' - param.SessionUid = sessionStorage.getItem('SessionUid') || '' - param.LoginUID = sessionStorage.getItem('LoginUID') || '' - param.appkey = window.GLOB.appkey || '' + visitOuterSystem (param, _resolve) { + let token = param.$token + delete param.$token - if (sessionStorage.getItem('isEditState') === 'true') { // HS涓嬭彍鍗� - param.userid = sessionStorage.getItem('CloudUserID') - param.SessionUid = sessionStorage.getItem('CloudSessionUid') || '' - param.LoginUID = sessionStorage.getItem('CloudLoginUID') || '' + try { + token = JSON.parse(token) + token = token.message + + const key = CryptoJS.enc.Utf8.parse(window.GLOB.appkey.slice(-16)) + const iv = CryptoJS.enc.Utf8.parse('mksoft') + + let encryptedHexStr = CryptoJS.enc.Hex.parse(token) + let _srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr) + let decrypt = CryptoJS.AES.decrypt(_srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 }) + let decryptedStr = decrypt.toString(CryptoJS.enc.Utf8) + token = decryptedStr.toString() + + token = JSON.parse(window.decodeURIComponent(window.atob(token))) + } catch (e) { + token = null + _resolve({status: false, ErrCode: 'E', message: '鎺ュ彛淇℃伅瑙f瀽澶辫触锛�', ErrMesg: 'token_error'}) } - param.nonc = Utils.getuuid() - - let keys = Object.keys(param).sort() - let values = '' - keys.forEach(key => { - if (key === 'rduri' || key === 't') return - if (typeof(param[key]) === 'object') { - values += key + JSON.stringify(param[key]) - } else { - values += key + param[key] - } - }) - param.sign = md5(values) - param.t = new Date().getTime() + if (!token) return - return axios({ - url: `/webapi/dostars${param.func ? '/' + param.func : ''}`, - data: param - }) + let userid = '' + let loginUid = '' + let dataM = '' + + if (window.GLOB.OuterToken[token.interface]) { + let msg = window.GLOB.OuterToken[token.interface] + + let seconds = Math.floor((new Date().getTime() - msg.timestamp) / 1000) + if (seconds >= 3600) { + delete window.GLOB.OuterToken[token.interface] + } else { + userid = msg.userid + loginUid = msg.loginUid + dataM = msg.dataM || '' + } + } + + // param.appkey = token.appkey || '' + + if (userid && loginUid) { + param.dataM = dataM + param.userid = userid + param.LoginUID = loginUid + param = this.encryptParam(param) + + axios({ + url: token.interface, + method: 'post', + data: JSON.stringify(param) + }).then(res => { + _resolve(res) + }) + } else { + let _param = { + UserName: token.username, + systemType: window.GLOB.sysType, + login_city: sessionStorage.getItem('city') || '', + device_id: token.appkey || '', + timestamp: moment().format('YYYY-MM-DD HH:mm:ss'), + Type: token.publicKey, + appkey: token.appkey || '' + } + + let shaObj = new jsSHA('SHA-1', 'TEXT') + shaObj.update(token.password) + _param.Password = shaObj.getHash('HEX').toUpperCase() + _param.Password = md5(token.privateKey + token.username + _param.Password + _param.timestamp) + + let url = token.interface.replace(/\/webapi(.*)/, '/webapi/dologon') + + if (token.ssoInterface) { + _param.rduri = token.ssoInterface.replace(/\/webapi(.*)/, '/webapi/dologon') + } + + axios({ + url, + method: 'post', + data: JSON.stringify(_param) + }).then(result => { + if (result.status) { + window.GLOB.OuterToken[token.interface] = { + userid: result.UserID, + loginUid: result.LoginUID, + timestamp: new Date().getTime(), + dataM: result.dataM ? 'Y' : '' + } + + param.dataM = result.dataM ? 'Y' : '' + param.userid = result.UserID + param.LoginUID = result.LoginUID + param = this.encryptParam(param) + + axios({ + url: token.interface, + method: 'post', + data: JSON.stringify(param) + }).then(res => { + _resolve(res) + }) + } else { + _resolve(result) + } + }) + } } /** - * @description 瀵煎嚭Excel + * @description 鑾峰彇涓氬姟閫氱敤鎺ュ彛 + * 璁块棶 'https://sso.mk9h.cn/webapi/dostars'鎴栦簯绔椂锛屼紶鍏serid銆丩oginUID */ - getExcelOut (param, name) { - param.userid = sessionStorage.getItem('UserID') - param.lang = localStorage.getItem('lang') || '' - param.SessionUid = sessionStorage.getItem('SessionUid') || '' - param.LoginUID = sessionStorage.getItem('LoginUID') || '' + genericInterface (param) { + param.userid = param.userid || sessionStorage.getItem('UserID') || '' + param.lang = param.lang || sessionStorage.getItem('lang') || '' + param.SessionUid = localStorage.getItem('SessionUid') || '' + param.LoginUID = param.LoginUID || sessionStorage.getItem('LoginUID') || '' param.appkey = window.GLOB.appkey || '' - - return new Promise(resolve => { - axios({ - url: '/webapi/doexcel', - responseType: 'blob', - data: param - }).then(res => { - try { - const blob = new Blob([res]) - - if (res.type === 'application/json') { - const reader = new FileReader() - reader.onload = e => resolve(JSON.parse(e.target.result)) - reader.readAsText(blob) + if (param.$token === '') { + return Promise.resolve({status: false, ErrCode: 'E', message: '鎺ュ彛鍦板潃灏氭湭璁剧疆锛�', ErrMesg: 'token_error'}) + } else if (param.$token) { + return new Promise(resolve => this.visitOuterSystem(param, resolve)) + } + + if (['sPC_TableData_InUpDe', 'sPC_TableData_InUpDe_debug'].includes(param.func)) { + param.username = sessionStorage.getItem('User_Name') || '' + param.fullname = sessionStorage.getItem('Full_Name') || '' + } + + let login = false + let rduri = null + + if (param.rduri && /\s|\n/.test(param.rduri)) { + param.rduri = param.rduri.replace(/\s|\n/g, '') + if (!param.rduri) { + delete param.rduri + } + } + + if (param.$login && !window.GLOB.transfer) { + login = true + rduri = param.rduri || '' + } + delete param.$login + + let url = '/webapi/dostars' + + if (param.rduri && !window.GLOB.transfer && /\/dostars/.test(param.rduri) && param.func !== 'webapi_ChangeUser') { + url = param.rduri + delete param.rduri + } + + param = this.encryptParam(param) + + if (login) { + let time = +sessionStorage.getItem(rduri) + let c_time = Math.round(new Date().getTime() / 1000) + + if (time && c_time - time <= 60) { + sessionStorage.setItem(rduri, c_time) + return axios({ + url: `${url}${param.func ? '/' + param.func : ''}`, + method: 'post', + data: JSON.stringify(param) + }) + } + + return new Promise((resolve, reject) => { + this.getTouristMsg('login_check', rduri).then(res => { + if (res.status) { + sessionStorage.setItem(rduri, c_time) + axios({ + url: `${url}${param.func ? '/' + param.func : ''}`, + method: 'post', + data: JSON.stringify(param) + }).then(result => { + resolve(result) + }) } else { - if ('download' in document.createElement('a')) { // 闈濱E涓嬭浇 - const elink = document.createElement('a') - elink.download = name - elink.style.display = 'none' - elink.href = URL.createObjectURL(blob) - document.body.appendChild(elink) - elink.click() - URL.revokeObjectURL(elink.href) // 閲婃斁URL 瀵硅薄 - document.body.removeChild(elink) - } else { // IE10+涓嬭浇 - navigator.msSaveBlob(blob, name) - } - resolve() + resolve(res) } - } catch { - resolve({ - ErrCode: 'E', - ErrMesg: '鏂囦欢瑙f瀽閿欒', - message: '', - status: false - }) - } + }) }) - }) + } else { + return axios({ + url: `${url}${param.func ? '/' + param.func : ''}`, + method: 'post', + data: JSON.stringify(param) + }) + } } /** * @description 涓婁紶base64 * @param {String} base64 base64鍥剧墖缂栫爜 */ - fileuploadbase64 (base64, service = 'local') { - let param = { - func: '', - BasePath: 'Content/Upload', - lang: localStorage.getItem('lang') || '', - appkey: window.GLOB.appkey || '', - Base64Img: base64 - } + fileuploadbase64 (param) { + param.func = '' + param.BasePath = 'Content/Upload' + param.lang = sessionStorage.getItem('lang') || '' + param.appkey = window.GLOB.appkey || '' + param.SessionUid = localStorage.getItem('SessionUid') || '' - if (service === 'sso' && window.GLOB.mainSystemApi) { - param.rduri = window.GLOB.mainSystemApi - param.userid = sessionStorage.getItem('UserID') - param.SessionUid = sessionStorage.getItem('SessionUid') || '' - param.LoginUID = sessionStorage.getItem('LoginUID') || '' - } else if (service === 'cloud' && options.cloudServiceApi) { - param.rduri = options.cloudServiceApi - param.userid = sessionStorage.getItem('CloudUserID') - param.SessionUid = sessionStorage.getItem('CloudSessionUid') || '' - param.LoginUID = sessionStorage.getItem('CloudLoginUID') || '' - } else { - param.userid = sessionStorage.getItem('UserID') - param.SessionUid = sessionStorage.getItem('SessionUid') || '' - param.LoginUID = sessionStorage.getItem('LoginUID') || '' - } + param.userid = param.userid || sessionStorage.getItem('UserID') || '' + param.LoginUID = param.LoginUID || sessionStorage.getItem('LoginUID') || '' - param.nonc = Utils.getuuid() - - let keys = Object.keys(param).sort() - let values = '' - keys.forEach(key => { - if (key === 'rduri' || key === 't') return - if (typeof(param[key]) === 'object') { - values += key + JSON.stringify(param[key]) - } else { - values += key + param[key] - } - }) - param.sign = md5(values) - param.t = new Date().getTime() + param = this.encryptParam(param) + + let url = '/webapi/SaveBase64Image' if (param.rduri) { param.rduri = param.rduri.replace(/webapi(.*)$/, 'webapi/SaveBase64Image') - - return axios({ - url: '/webapi/dostars', - data: param - }) - } else { - return axios({ - url: '/webapi/SaveBase64Image', - data: param - }) + if (/\s|\n/.test(param.rduri)) { + param.rduri = param.rduri.replace(/\s|\n/g, '') + if (!param.rduri) { + delete param.rduri + } + } } + + if (param.rduri && !window.GLOB.transfer) { + url = param.rduri + delete param.rduri + } + + return axios({ + url, + method: 'post', + data: JSON.stringify(param) + }) } /** @@ -433,6 +946,8 @@ getLargeFileUpload (param) { return axios({ url: '/webapi/doupload', + method: 'post', + headers: { 'Content-Type': 'multipart/form-data' }, data: param }) } @@ -443,6 +958,36 @@ getFilePreUpload (param) { return axios({ url: '/webapi/dopreload', + method: 'post', + headers: { 'Content-Type': 'multipart/form-data' }, + data: param + }) + } + + /** + * @description oss鏂囦欢涓婁紶 + */ + fileOssUpload (param) { + let _url = window.GLOB.location + '/file/oss/upload' + if (process.env.NODE_ENV === 'production') { + _url = document.location.origin + '/file/oss/upload' + } + if (/^http:\/\/(qingqiumarket.cn|cloud.mk9h.cn|sso.mk9h.cn)/.test(_url)) { + _url = window.GLOB.location + ':8080/file/oss/upload' + if (process.env.NODE_ENV === 'production') { + _url = document.location.origin + ':8080/file/oss/upload' + } + } else if (/^https:\/\/(qingqiumarket.cn|cloud.mk9h.cn|sso.mk9h.cn)/.test(_url)) { + _url = window.GLOB.location + ':8443/file/oss/upload' + if (process.env.NODE_ENV === 'production') { + _url = document.location.origin + ':8443/file/oss/upload' + } + } + + return axios({ + url: _url, + method: 'post', + headers: { 'Content-Type': 'multipart/form-data' }, data: param }) } @@ -451,53 +996,20 @@ * @description 鑾峰彇寰俊鏀粯浜岀淮鐮� */ getWxNativePay (param) { + let _url = window.GLOB.baseurl + 'wxpay/wxNativePay' + return axios({ - url: '/wxpay/wxNativePay', - data: param + url: _url, + method: 'post', + data: qs.stringify(param) }) } - /** - * @description 鏂囦欢涓婁紶 - */ - getFileUpload (param) { + postekPrint (data) { return axios({ - url: '/zh-CN/Home/Upload', - data: param - }) - } - - /** - * @description 閫氱敤鎺ュ彛(鏁版嵁绠$悊) - * @param {Object} param 鏌ヨ鍙婃彁浜ゅ弬鏁� - */ - commonInterface (param) { - param.userid = sessionStorage.getItem('UserID') - param.lang = localStorage.getItem('lang') || '' - param.SessionUid = sessionStorage.getItem('SessionUid') || '' - param.LoginUID = sessionStorage.getItem('LoginUID') || '' - param.BID = param.BID || '' - param.debug = param.debug || '' - - return axios({ - url: '/webapi/dostar', - data: param - }) - } - - /** - * @description 閫氱敤鎺ュ彛(鎻愪氦)(鏁版嵁绠$悊) - * @param {Object} param 鏌ヨ鍙婃彁浜ゅ弬鏁� - */ - submitInterface (param) { - param.userid = sessionStorage.getItem('UserID') - param.lang = localStorage.getItem('lang') || '' - param.SessionUid = sessionStorage.getItem('SessionUid') || '' - param.LoginUID = sessionStorage.getItem('LoginUID') || '' - - return axios({ - url: '/webapi/dostar', - data: param + url: 'http://127.0.0.1:888/postek/print', + method: 'post', + data: qs.stringify(data) }) } } -- Gitblit v1.8.0