✨新增全局异常提示
This commit is contained in:
parent
b4a37d06c1
commit
405a8ce511
@ -9,7 +9,7 @@ import useSettingsStore from '@/store/modules/settings'
|
||||
import usePermissionStore from '@/store/modules/permission'
|
||||
NProgress.configure({ showSpinner: false })
|
||||
|
||||
const whiteList = ['/login', '/auth-redirect', '/bind', '/register', '/socialLogin']
|
||||
const whiteList = ['/login', '/auth-redirect', '/bind', '/register', '/socialLogin', '/error']
|
||||
|
||||
router.beforeEach((to, from, next) => {
|
||||
NProgress.start()
|
||||
|
||||
@ -59,6 +59,11 @@ export const constantRoutes = [
|
||||
component: () => import('@/views/error/401'),
|
||||
hidden: true
|
||||
},
|
||||
{
|
||||
path: '/error',
|
||||
component: () => import('@/views/error/Error'),
|
||||
hidden: true
|
||||
},
|
||||
{
|
||||
path: '',
|
||||
component: Layout,
|
||||
|
||||
@ -1,5 +1,4 @@
|
||||
// import signalr from './signalr'
|
||||
import { ElNotification, ElMessage, ElMessageBox } from 'element-plus'
|
||||
import { ElNotification, ElMessageBox } from 'element-plus'
|
||||
import useSocketStore from '@/store/modules/socket'
|
||||
import useUserStore from '@/store/modules/user'
|
||||
import { webNotify } from '@/utils/index'
|
||||
@ -38,16 +37,21 @@ export default {
|
||||
|
||||
// 接收强退通知
|
||||
connection.on('forceUser', (data) => {
|
||||
ElMessageBox.alert(`你的账号已被强退,原因:${data.reason || '无'}`, '提示', {
|
||||
confirmButtonText: '确定',
|
||||
callback: () => {
|
||||
useUserStore()
|
||||
.logOut()
|
||||
.then(() => {
|
||||
location.href = import.meta.env.VITE_APP_ROUTER_PREFIX + 'index'
|
||||
})
|
||||
}
|
||||
})
|
||||
// connection.stop().then(() => {
|
||||
// console.log('Connection stoped')
|
||||
// })
|
||||
// ElMessageBox.alert(`你的账号已被强退,原因:${data.reason || '无'}`, '提示', {
|
||||
// confirmButtonText: '确定',
|
||||
// callback: () => {
|
||||
|
||||
// }
|
||||
// })
|
||||
useSocketStore().setGlobalError({ code: 0, msg: `你的账号已被强退,原因:${data.reason || '无'}` })
|
||||
useUserStore()
|
||||
.logOut()
|
||||
.then(() => {
|
||||
location.href = import.meta.env.VITE_APP_ROUTER_PREFIX + 'error'
|
||||
})
|
||||
})
|
||||
// 接收聊天数据
|
||||
connection.on('receiveChat', (data) => {
|
||||
@ -70,7 +74,7 @@ export default {
|
||||
useSocketStore().getOnlineInfo(data)
|
||||
})
|
||||
|
||||
connection.on('logOut', () => {
|
||||
connection.on(MsgType.LogOut, () => {
|
||||
useUserStore()
|
||||
.logOut()
|
||||
.then(() => {
|
||||
@ -86,5 +90,6 @@ export default {
|
||||
}
|
||||
const MsgType = {
|
||||
M001: 'onlineNum',
|
||||
M002: 'connId'
|
||||
M002: 'connId',
|
||||
LogOut: 'logOut'
|
||||
}
|
||||
|
||||
@ -41,7 +41,6 @@ export default {
|
||||
await this.start()
|
||||
})
|
||||
analysis.onMessage(connection)
|
||||
// this.receiveMsg(connection)
|
||||
// 启动
|
||||
// this.start();
|
||||
},
|
||||
@ -70,7 +69,5 @@ export default {
|
||||
}
|
||||
return false
|
||||
}
|
||||
},
|
||||
// 接收消息处理
|
||||
receiveMsg(connection) {}
|
||||
}
|
||||
}
|
||||
|
||||
@ -2,7 +2,7 @@ import useUserStore from './user'
|
||||
import signalR from '@/signalr/signalr'
|
||||
const useSocketStore = defineStore('socket', {
|
||||
persist: {
|
||||
paths: ['chatMessage', 'chatList', 'sessionList', 'newChat', 'noticeIdArr', 'newNotice'] //存储指定key
|
||||
paths: ['chatMessage', 'chatList', 'sessionList', 'newChat', 'noticeIdArr', 'newNotice', 'globalErrorMsg'] //存储指定key
|
||||
},
|
||||
state: () => ({
|
||||
onlineNum: 0,
|
||||
@ -16,7 +16,9 @@ const useSocketStore = defineStore('socket', {
|
||||
sessionList: {},
|
||||
newChat: 0,
|
||||
newNotice: 0,
|
||||
noticeIdArr: []
|
||||
noticeIdArr: [],
|
||||
// 全局错误提醒
|
||||
globalErrorMsg: {}
|
||||
}),
|
||||
getters: {
|
||||
/**
|
||||
@ -113,6 +115,9 @@ const useSocketStore = defineStore('socket', {
|
||||
} else if (type == 1) {
|
||||
this.newChat = 0
|
||||
}
|
||||
},
|
||||
setGlobalError(data) {
|
||||
this.globalErrorMsg = data
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
@ -1,159 +0,0 @@
|
||||
// 官方文档:https://docs.microsoft.com/zh-cn/aspnet/core/signalr/javascript-client?view=aspnetcore-6.0&viewFallbackFrom=aspnetcore-2.2&tabs=visual-studio
|
||||
import * as signalR from '@microsoft/signalr'
|
||||
import { getToken } from '@/utils/auth'
|
||||
import { ElNotification, ElMessage, ElMessageBox } from 'element-plus'
|
||||
import useSocketStore from '@/store/modules/socket'
|
||||
import useUserStore from '@/store/modules/user'
|
||||
import { webNotify } from './index'
|
||||
export default {
|
||||
// signalR对象
|
||||
SR: {},
|
||||
// 失败连接重试次数
|
||||
failNum: 4,
|
||||
init(url) {
|
||||
var socketUrl = window.location.origin + url
|
||||
const connection = new signalR.HubConnectionBuilder()
|
||||
.withUrl(socketUrl, { accessTokenFactory: () => getToken() })
|
||||
.withAutomaticReconnect() //自动重新连接
|
||||
.configureLogging(signalR.LogLevel.Warning)
|
||||
.build()
|
||||
this.SR = connection
|
||||
// 断线重连
|
||||
connection.onclose(async (error) => {
|
||||
console.error('断开连接了' + error)
|
||||
console.assert(connection.state === signalR.HubConnectionState.Disconnected)
|
||||
// 建议用户重新刷新浏览器
|
||||
await this.start()
|
||||
})
|
||||
|
||||
connection.onreconnected((connectionId) => {
|
||||
ElMessage({
|
||||
message: '与服务器通讯已连接成功',
|
||||
type: 'success',
|
||||
duration: 2000
|
||||
})
|
||||
console.log('断线重新连接成功' + connectionId)
|
||||
})
|
||||
|
||||
connection.onreconnecting(async () => {
|
||||
console.log('断线重新连接中... ')
|
||||
|
||||
await this.start()
|
||||
})
|
||||
|
||||
this.receiveMsg(connection)
|
||||
// 启动
|
||||
// this.start();
|
||||
},
|
||||
/**
|
||||
* 调用 this.signalR.start().then(async () => { await this.SR.invoke("method")})
|
||||
* @returns
|
||||
*/
|
||||
async start() {
|
||||
try {
|
||||
console.log('signalR-1', this.SR.state)
|
||||
//使用async和await 或 promise的then 和catch 处理来自服务端的异常
|
||||
if (this.SR.state === signalR.HubConnectionState.Disconnected) {
|
||||
await this.SR.start()
|
||||
}
|
||||
|
||||
console.log('signalR-2', this.SR.state)
|
||||
return true
|
||||
} catch (error) {
|
||||
console.error(error)
|
||||
this.failNum--
|
||||
// console.log(`失败重试剩余次数${that.failNum}`, error)
|
||||
if (this.failNum > 0 && this.SR.state.Disconnected) {
|
||||
setTimeout(async () => {
|
||||
await this.start()
|
||||
}, 5000)
|
||||
}
|
||||
return false
|
||||
}
|
||||
},
|
||||
// 接收消息处理
|
||||
receiveMsg(connection) {
|
||||
connection.on('onlineNum', (data) => {
|
||||
useSocketStore().setOnlineUsers(data)
|
||||
})
|
||||
// 接收欢迎语
|
||||
connection.on('welcome', (data) => {
|
||||
ElNotification.info(data)
|
||||
})
|
||||
connection.on('connId', (data) => {
|
||||
// useUserStore().saveConnId(data)
|
||||
})
|
||||
// 接收后台手动推送消息
|
||||
connection.on('receiveNotice', (title, data) => {
|
||||
ElNotification({
|
||||
type: 'info',
|
||||
title: title,
|
||||
message: data,
|
||||
dangerouslyUseHTMLString: true,
|
||||
duration: 0
|
||||
})
|
||||
webNotify({ title: title, body: data })
|
||||
})
|
||||
// 接收系统通知/公告
|
||||
connection.on('moreNotice', (data) => {
|
||||
if (data.code == 200) {
|
||||
useSocketStore().setNoticeList(data.data)
|
||||
}
|
||||
})
|
||||
|
||||
// 接收在线用户
|
||||
// connection.on('onlineUser', (data) => {
|
||||
// useSocketStore().setOnlineUsers(data)
|
||||
// })
|
||||
|
||||
// 接收封锁通知
|
||||
connection.on('lockUser', (data) => {
|
||||
ElMessageBox.alert(`你的账号已被锁定,剩余,${data.time}分,原因:${data.reason || '-'}`, '提示', {
|
||||
confirmButtonText: '确定',
|
||||
callback: (action) => {
|
||||
useUserStore()
|
||||
.logOut()
|
||||
.then(() => {
|
||||
var redirectUrl = window.location.pathname
|
||||
if (location.pathname.indexOf('/login') != 0) {
|
||||
location.href = import.meta.env.VITE_APP_ROUTER_PREFIX + 'index?redirect=' + redirectUrl
|
||||
}
|
||||
})
|
||||
}
|
||||
})
|
||||
})
|
||||
// 接收聊天数据
|
||||
connection.on('receiveChat', (data) => {
|
||||
const title = `来自${data.userName}的消息通知`
|
||||
useSocketStore().setChat(data)
|
||||
|
||||
if (data.userid != useUserStore().userId) {
|
||||
ElNotification({
|
||||
title: title,
|
||||
message: data.message,
|
||||
type: 'success',
|
||||
duration: 3000
|
||||
})
|
||||
}
|
||||
webNotify({ title: title, body: data.message })
|
||||
})
|
||||
|
||||
connection.on('onlineInfo', (data) => {
|
||||
console.log('onlineInfo', data)
|
||||
useSocketStore().getOnlineInfo(data)
|
||||
})
|
||||
|
||||
connection.on('logOut', () => {
|
||||
useUserStore()
|
||||
.logOut()
|
||||
.then(() => {
|
||||
ElMessageBox.alert(`你的账号已在其他设备登录,如果不是你的操作请尽快修改密码`, '提示', {
|
||||
confirmButtonText: '确定',
|
||||
callback: () => {
|
||||
location.href = import.meta.env.VITE_APP_ROUTER_PREFIX + 'index'
|
||||
}
|
||||
})
|
||||
})
|
||||
})
|
||||
}
|
||||
}
|
||||
69
src/views/error/Error.vue
Normal file
69
src/views/error/Error.vue
Normal file
@ -0,0 +1,69 @@
|
||||
<template>
|
||||
<div class="errPage-container">
|
||||
<el-row>
|
||||
<el-col :span="12">
|
||||
<h1 class="text-jumbo text-ginormous">提示!</h1>
|
||||
<h3 class="text-danger">{{ msgObj.msg }}</h3>
|
||||
<!-- <h6>{{ msgObj }}</h6> -->
|
||||
<div class="list-unstyled">
|
||||
<router-link to="/"> 回首页 </router-link>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :span="12">
|
||||
<img :src="errGif" width="313" height="428" alt="Girl has dropped her ice cream." />
|
||||
</el-col>
|
||||
</el-row>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
import errImage from '@/assets/401_images/401.gif'
|
||||
import useSocketStore from '@/store/modules/socket'
|
||||
let { proxy } = getCurrentInstance()
|
||||
const socketStore = useSocketStore()
|
||||
|
||||
const msgObj = computed(() => {
|
||||
return socketStore.globalErrorMsg
|
||||
})
|
||||
const errGif = ref(errImage + '?' + +new Date())
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
.errPage-container {
|
||||
width: 800px;
|
||||
max-width: 100%;
|
||||
margin: 100px auto;
|
||||
.pan-back-btn {
|
||||
background: #008489;
|
||||
color: #fff;
|
||||
border: none !important;
|
||||
}
|
||||
.pan-gif {
|
||||
margin: 0 auto;
|
||||
display: block;
|
||||
}
|
||||
.pan-img {
|
||||
display: block;
|
||||
margin: 0 auto;
|
||||
width: 100%;
|
||||
}
|
||||
.text-jumbo {
|
||||
font-size: 60px;
|
||||
font-weight: 700;
|
||||
color: #484848;
|
||||
}
|
||||
.list-unstyled {
|
||||
font-size: 14px;
|
||||
li {
|
||||
padding-bottom: 5px;
|
||||
}
|
||||
a {
|
||||
color: #008489;
|
||||
text-decoration: none;
|
||||
&:hover {
|
||||
text-decoration: underline;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
</style>
|
||||
Loading…
x
Reference in New Issue
Block a user