first commit
This commit is contained in:
24
pgapp/utils/auth.js
Normal file
24
pgapp/utils/auth.js
Normal file
@@ -0,0 +1,24 @@
|
||||
const TokenKey = 'App-Token'
|
||||
const UserKey = 'UserID'
|
||||
export function getToken() {
|
||||
return uni.getStorageSync(TokenKey)
|
||||
}
|
||||
|
||||
export function setToken(token) {
|
||||
return uni.setStorageSync(TokenKey, token)
|
||||
}
|
||||
|
||||
export function removeToken() {
|
||||
return uni.removeStorageSync(TokenKey)
|
||||
}
|
||||
export function getUserID() {
|
||||
return uni.getStorageSync(UserKey)
|
||||
}
|
||||
|
||||
export function setUserID(userId) {
|
||||
return uni.setStorageSync(UserKey, userId)
|
||||
}
|
||||
|
||||
export function removeUserID() {
|
||||
return uni.removeStorageSync(UserKey)
|
||||
}
|
||||
122
pgapp/utils/common.js
Normal file
122
pgapp/utils/common.js
Normal file
@@ -0,0 +1,122 @@
|
||||
/**
|
||||
* 显示消息提示框
|
||||
* @param content { icon:'none/loading/sucess/fail/exception/', title:'(您要显示的文字消息)'} 提示的标题
|
||||
*/
|
||||
export function toast(content) {
|
||||
uni.showToast({
|
||||
icon:'none',
|
||||
title: content
|
||||
})
|
||||
}
|
||||
|
||||
/**
|
||||
* 显示模态弹窗
|
||||
* @param content 提示的标题
|
||||
*/
|
||||
export function showConfirm(content) {
|
||||
return new Promise((resolve, reject) => {
|
||||
uni.showModal({
|
||||
title: '提示',
|
||||
content: content,
|
||||
cancelText: '取消',
|
||||
confirmText: '确定',
|
||||
success: function(res) {
|
||||
resolve(res)
|
||||
}
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
/**
|
||||
* 解密
|
||||
* @param {*} hexString
|
||||
* @returns
|
||||
*/
|
||||
export function decrypto( hexString ) {
|
||||
return JSON.parse( Buffer.from(hexString, 'hex').toString('binary') )
|
||||
}
|
||||
|
||||
/**
|
||||
* 加密
|
||||
* @param {*} jsonString
|
||||
* @returns
|
||||
*/
|
||||
export function encrypto (jsonString) {
|
||||
return Buffer.from(JSON.stringify(jsonString), 'binary').toString('hex')
|
||||
}
|
||||
|
||||
/**
|
||||
* 参数处理
|
||||
* @param params 参数
|
||||
*/
|
||||
export function tansParams(params) {
|
||||
let result = ''
|
||||
for (const propName of Object.keys(params)) {
|
||||
const value = params[propName]
|
||||
var part = encodeURIComponent(propName) + "="
|
||||
if (value !== null && value !== "" && typeof (value) !== "undefined") {
|
||||
if (typeof value === 'object') {
|
||||
for (const key of Object.keys(value)) {
|
||||
if (value[key] !== null && value[key] !== "" && typeof (value[key]) !== 'undefined') {
|
||||
let params = propName + '[' + key + ']'
|
||||
var subPart = encodeURIComponent(params) + "="
|
||||
result += subPart + encodeURIComponent(value[key]) + "&"
|
||||
}
|
||||
}
|
||||
} else {
|
||||
result += part + encodeURIComponent(value) + "&"
|
||||
}
|
||||
}
|
||||
}
|
||||
return result
|
||||
}
|
||||
|
||||
/**
|
||||
* 复制粘贴板
|
||||
* @param {String} text 需要复制的dom元素
|
||||
*/
|
||||
export const copyFn = (text) => {
|
||||
// 处理 Vue 组件实例(如果 ref 绑定在组件上)
|
||||
if (text && text.$el && text.$el instanceof Node) {
|
||||
text = text.$el;
|
||||
}
|
||||
|
||||
// 严格验证节点类型
|
||||
if (!(text instanceof Node) || typeof text.nodeType !== 'number') {
|
||||
uni.showToast({ title: '复制失败:无效内容', icon: 'none' });
|
||||
return;
|
||||
}
|
||||
|
||||
let range, selection;
|
||||
try {
|
||||
if (document.body.createTextRange) {
|
||||
range = document.body.createTextRange();
|
||||
range.moveToElementText(text);
|
||||
range.select();
|
||||
} else if (window.getSelection) {
|
||||
selection = window.getSelection();
|
||||
range = document.createRange();
|
||||
// 再次验证节点有效性
|
||||
if (text.isConnected) {
|
||||
range.selectNodeContents(text);
|
||||
selection.removeAllRanges();
|
||||
selection.addRange(range);
|
||||
} else {
|
||||
throw new Error('节点已从DOM中移除');
|
||||
}
|
||||
} else {
|
||||
throw new Error('浏览器不支持复制操作');
|
||||
}
|
||||
|
||||
const success = document.execCommand('Copy');
|
||||
uni.showToast({ title: success ? '复制成功' : '复制失败', icon: 'none' });
|
||||
} catch (e) {
|
||||
uni.showToast({ title: `复制失败:${e.message}`, icon: 'none' });
|
||||
console.error('复制错误:', e);
|
||||
} finally {
|
||||
// 清除选中状态(避免iOS等设备上的视觉残留)
|
||||
if (selection && range) {
|
||||
setTimeout(() => selection.removeAllRanges(), 100);
|
||||
}
|
||||
}
|
||||
}
|
||||
10
pgapp/utils/constant.js
Normal file
10
pgapp/utils/constant.js
Normal file
@@ -0,0 +1,10 @@
|
||||
const constant = {
|
||||
userId:'vuex_userId',
|
||||
//avatar: 'vuex_avatar',
|
||||
avatar: '',
|
||||
name: 'vuex_name',
|
||||
roles: 'vuex_roles',
|
||||
permissions: 'vuex_permissions'
|
||||
}
|
||||
|
||||
export default constant
|
||||
6
pgapp/utils/errorCode.js
Normal file
6
pgapp/utils/errorCode.js
Normal file
@@ -0,0 +1,6 @@
|
||||
export default {
|
||||
'401': '认证失败,无法访问系统资源',
|
||||
'403': '当前操作没有权限',
|
||||
'404': '访问资源不存在',
|
||||
'default': '系统未知错误,请反馈给管理员'
|
||||
}
|
||||
51
pgapp/utils/permission.js
Normal file
51
pgapp/utils/permission.js
Normal file
@@ -0,0 +1,51 @@
|
||||
import store from '@/store'
|
||||
|
||||
/**
|
||||
* 字符权限校验
|
||||
* @param {Array} value 校验值
|
||||
* @returns {Boolean}
|
||||
*/
|
||||
export function checkPermi(value) {
|
||||
if (value && value instanceof Array && value.length > 0) {
|
||||
const permissions = store.getters && store.getters.permissions
|
||||
const permissionDatas = value
|
||||
const all_permission = "*:*:*"
|
||||
|
||||
const hasPermission = permissions.some(permission => {
|
||||
return all_permission === permission || permissionDatas.includes(permission)
|
||||
})
|
||||
|
||||
if (!hasPermission) {
|
||||
return false
|
||||
}
|
||||
return true
|
||||
} else {
|
||||
console.error(`need roles! Like checkPermi="['system:user:add','system:user:edit']"`)
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 角色权限校验
|
||||
* @param {Array} value 校验值
|
||||
* @returns {Boolean}
|
||||
*/
|
||||
export function checkRole(value) {
|
||||
if (value && value instanceof Array && value.length > 0) {
|
||||
const roles = store.getters && store.getters.roles
|
||||
const permissionRoles = value
|
||||
const super_admin = "admin"
|
||||
|
||||
const hasRole = roles.some(role => {
|
||||
return super_admin === role || permissionRoles.includes(role)
|
||||
})
|
||||
|
||||
if (!hasRole) {
|
||||
return false
|
||||
}
|
||||
return true
|
||||
} else {
|
||||
console.error(`need roles! Like checkRole="['admin','editor']"`)
|
||||
return false
|
||||
}
|
||||
}
|
||||
76
pgapp/utils/request.js
Normal file
76
pgapp/utils/request.js
Normal file
@@ -0,0 +1,76 @@
|
||||
import store from '@/store'
|
||||
import config from '@/config'
|
||||
import { getToken, getUserID } from '@/utils/auth'
|
||||
import errorCode from '@/utils/errorCode'
|
||||
import { toast, showConfirm, tansParams } from '@/utils/common'
|
||||
|
||||
let timeout = 10000
|
||||
const baseUrl = config.baseUrl
|
||||
|
||||
const request = config => {
|
||||
// 是否需要设置 token
|
||||
const isToken = (config.header || {}).isToken === false
|
||||
config.header = config.header || {}
|
||||
if (getToken() && !isToken) {
|
||||
//config.header['Authorization'] = 'Bearer ' + getToken()
|
||||
config.header['ApiAuth'] = getToken()
|
||||
config.header['userId'] = getUserID()
|
||||
} else {
|
||||
uni.reLaunch({ url: '/pages/login' })
|
||||
}
|
||||
// get请求映射params参数
|
||||
if (config.params) {
|
||||
let url = config.url + '?' + tansParams(config.params)
|
||||
url = url.slice(0, -1)
|
||||
config.url = url
|
||||
}
|
||||
return new Promise((resolve, reject) => {
|
||||
uni.request({
|
||||
method: config.method || 'get',
|
||||
timeout: config.timeout || timeout,
|
||||
url: config.baseUrl || baseUrl + config.url,
|
||||
data: config.data,
|
||||
header: config.header,
|
||||
dataType: 'json'
|
||||
}).then(response => {
|
||||
let [error, res] = response
|
||||
if (error) {
|
||||
toast('后端接口连接异常')
|
||||
reject('后端接口连接异常')
|
||||
return
|
||||
}
|
||||
|
||||
const code = res.statusCode || 200
|
||||
|
||||
const msg = res.errMsg || errorCode['default']
|
||||
if (code === 401) {
|
||||
showConfirm('登录状态已过期,您可以继续留在该页面,或者重新登录?').then(res => {
|
||||
if (res.confirm) {
|
||||
store.dispatch('LogOut').then(res => {
|
||||
uni.reLaunch({ url: '/pages/login' })
|
||||
})
|
||||
}
|
||||
})
|
||||
reject('无效的会话,或者会话已过期,请重新登录。')
|
||||
} else if (code === 500) {
|
||||
toast(msg)
|
||||
reject('500')
|
||||
} else if (code !== 200) {
|
||||
toast(msg)
|
||||
reject(code)
|
||||
}
|
||||
resolve(res.data)
|
||||
})
|
||||
.catch(error => {
|
||||
let { message } = error
|
||||
if (message) {
|
||||
toast(message)
|
||||
} else {
|
||||
toast(error)
|
||||
}
|
||||
reject(error)
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
export default request
|
||||
33
pgapp/utils/storage.js
Normal file
33
pgapp/utils/storage.js
Normal file
@@ -0,0 +1,33 @@
|
||||
import constant from './constant'
|
||||
|
||||
// 存储变量名
|
||||
let storageKey = 'storage_data'
|
||||
|
||||
// 存储节点变量名
|
||||
let storageNodeKeys = [constant.userId, constant.avatar, constant.name, constant.roles, constant.permissions]
|
||||
|
||||
// 存储的数据
|
||||
let storageData = uni.getStorageSync(storageKey) || {}
|
||||
|
||||
const storage = {
|
||||
set: function(key, value) {
|
||||
if (storageNodeKeys.indexOf(key) != -1) {
|
||||
let tmp = uni.getStorageSync(storageKey)
|
||||
tmp = tmp ? tmp : {}
|
||||
tmp[key] = value
|
||||
uni.setStorageSync(storageKey, tmp)
|
||||
}
|
||||
},
|
||||
get: function(key) {
|
||||
return storageData[key] || ""
|
||||
},
|
||||
remove: function(key) {
|
||||
delete storageData[key]
|
||||
uni.setStorageSync(storageKey, storageData)
|
||||
},
|
||||
clean: function() {
|
||||
uni.removeStorageSync(storageKey)
|
||||
}
|
||||
}
|
||||
|
||||
export default storage
|
||||
80
pgapp/utils/upload.js
Normal file
80
pgapp/utils/upload.js
Normal file
@@ -0,0 +1,80 @@
|
||||
import store from '@/store'
|
||||
import config from '@/config'
|
||||
import { getToken, getUserID } from '@/utils/auth'
|
||||
import errorCode from '@/utils/errorCode'
|
||||
import { toast, showConfirm, tansParams } from '@/utils/common'
|
||||
|
||||
let timeout = 600000
|
||||
const baseUrl = config.baseUrl
|
||||
|
||||
const upload = config => {
|
||||
// 是否需要设置 token
|
||||
const isToken = (config.header || {}).isToken === false
|
||||
config.header = config.header || {}
|
||||
if (getToken() && !isToken) {
|
||||
//config.header['Authorization'] = 'Bearer ' + getToken()
|
||||
config.header['ApiAuth'] = getToken()
|
||||
config.header['userId'] = getUserID()
|
||||
}
|
||||
// get请求映射params参数
|
||||
if (config.params) {
|
||||
let url = config.url + '?' + tansParams(config.params)
|
||||
url = url.slice(0, -1)
|
||||
config.url = url
|
||||
}
|
||||
return new Promise((resolve, reject) => {
|
||||
uni.uploadFile({
|
||||
timeout: config.timeout || timeout,
|
||||
url: baseUrl + config.url,
|
||||
filePath: config.filePath,
|
||||
name: config.name || 'pic',
|
||||
header: config.header,
|
||||
formData: config.formData,
|
||||
success: (res) => {
|
||||
window.console.log("uploadFile response-->")
|
||||
window.console.log(res)
|
||||
|
||||
const code = res.statusCode || 200
|
||||
|
||||
const msg = errorCode[code] || errorCode['default']
|
||||
if (code === 200) {
|
||||
let result = JSON.parse(res.data)
|
||||
resolve(result)
|
||||
} else if (code == 401) {
|
||||
showConfirm("登录状态已过期,您可以继续留在该页面,或者重新登录?").then(res => {
|
||||
if (res.confirm) {
|
||||
store.dispatch('LogOut').then(res => {
|
||||
uni.reLaunch({ url: '/pages/login/login' })
|
||||
})
|
||||
}
|
||||
})
|
||||
reject('无效的会话,或者会话已过期,请重新登录。')
|
||||
} else if (code === 500) {
|
||||
toast(msg)
|
||||
reject('500')
|
||||
} else if (code !== 200) {
|
||||
toast(msg)
|
||||
reject(code)
|
||||
}
|
||||
},
|
||||
fail: (error) => {
|
||||
window.console.log(error)
|
||||
let { message } = error
|
||||
|
||||
if(message == 'undefined') {
|
||||
toast(error)
|
||||
} else if (message == 'Network Error') {
|
||||
message = '后端接口连接异常'
|
||||
} else if (message.includes('timeout')) {
|
||||
message = '系统接口请求超时'
|
||||
} else if (message.includes('Request failed with status code')) {
|
||||
message = '系统接口' + message.substr(message.length - 3) + '异常'
|
||||
}
|
||||
toast(message)
|
||||
reject(error)
|
||||
}
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
export default upload
|
||||
Reference in New Issue
Block a user