first commit

This commit is contained in:
annnj-company
2026-04-17 18:29:53 +08:00
parent e49fa5a215
commit 130c1026c4
5615 changed files with 1639145 additions and 0 deletions

24
pgapp/utils/auth.js Normal file
View 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
View 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
View 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
View File

@@ -0,0 +1,6 @@
export default {
'401': '认证失败,无法访问系统资源',
'403': '当前操作没有权限',
'404': '访问资源不存在',
'default': '系统未知错误,请反馈给管理员'
}

51
pgapp/utils/permission.js Normal file
View 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
View 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
View 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
View 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