Browse Source

15分钟未操作返回首页

master
管理员 2 years ago
parent
commit
b795f534a0
  1. 76
      acs/nladmin-ui/src/App.vue
  2. 76
      lms/nladmin-ui/src/App.vue

76
acs/nladmin-ui/src/App.vue

@ -1,5 +1,5 @@
<template> <template>
<div id="app"> <div id="app" @mousemove="moveEvent" @click="moveEvent">
<router-view /> <router-view />
</div> </div>
</template> </template>
@ -7,63 +7,29 @@
<script> <script>
export default { export default {
name: 'App', name: 'App',
created() { data() {
this.webSocket() // token return {
timmer: null
}
}, },
methods: { methods: {
webSocket() { moveEvent: function() {
const that = this const path = ['/login']
if (typeof (WebSocket) === 'undefined') { if (!path.includes(this.$route.path)) {
this.$notify({ clearTimeout(this.timmer)
title: '提示', this.init()
message: '当前浏览器无法接收实时报警信息,请使用谷歌浏览器!',
type: 'warning',
duration: 0
})
} else {
const id = 'exp-token'
// tokenvuex
// socket使IP
// const socketUrl = process.env.VUE_APP_WS_API + id
const wsUri = window.g.prod.VUE_APP_BASE_API.replace('http', 'ws') + '/webSocket/' + id
this.socket = new WebSocket(wsUri)
// socket
this.socket.onopen = function() {
that.socket.send('测试客户端发送消息')
}
const _this = this
// socket
this.socket.onmessage = function(msg) {
const data = JSON.parse(msg.data)
_this.$confirm(data.msg, '提示', {
confirmButtonText: '确定',
closeOnClickModal: false,
showCancelButton: false,
type: 'warning'
}).then(() => {
_this.$router.push('/login')
}).catch(() => {
this.$message({
type: 'info',
message: '已取消'
})
})
}
// socket
this.socket.onerror = function() {
that.$notify({
title: '错误',
message: '服务器错误,无法接收实时报警信息',
type: 'error',
duration: 0
})
}
// socket
this.socket.onclose = function() {
console.log('WebSocket已关闭')
}
} }
},
init: function() {
this.timmer = setTimeout(() => {
sessionStorage.clear()
this.logout()
}, 1000 * 60 * 15) // 15分钟 https://blog.csdn.net/qq_42345108/article/details/103496456
},
logout() {
this.$store.dispatch('LogOut').then(() => {
location.reload()
})
} }
} }
} }

76
lms/nladmin-ui/src/App.vue

@ -1,5 +1,5 @@
<template> <template>
<div id="app"> <div id="app" @mousemove="moveEvent" @click="moveEvent">
<router-view /> <router-view />
</div> </div>
</template> </template>
@ -7,63 +7,29 @@
<script> <script>
export default { export default {
name: 'App', name: 'App',
created() { data() {
this.webSocket() // token return {
timmer: null
}
}, },
methods: { methods: {
webSocket() { moveEvent: function() {
const that = this const path = ['/login']
if (typeof (WebSocket) === 'undefined') { if (!path.includes(this.$route.path)) {
this.$notify({ clearTimeout(this.timmer)
title: '提示', this.init()
message: '当前浏览器无法接收实时报警信息,请使用谷歌浏览器!',
type: 'warning',
duration: 0
})
} else {
const id = 'exp-token'
// tokenvuex
// socket使IP
// const socketUrl = process.env.VUE_APP_WS_API + id
const wsUri = window.g.prod.VUE_APP_BASE_API.replace('http', 'ws') + '/webSocket/' + id
this.socket = new WebSocket(wsUri)
// socket
this.socket.onopen = function() {
that.socket.send('测试客户端发送消息')
}
const _this = this
// socket
this.socket.onmessage = function(msg) {
const data = JSON.parse(msg.data)
_this.$confirm(data.msg, '提示', {
confirmButtonText: '确定',
closeOnClickModal: false,
showCancelButton: false,
type: 'warning'
}).then(() => {
_this.$router.push('/login')
}).catch(() => {
this.$message({
type: 'info',
message: '已取消'
})
})
}
// socket
this.socket.onerror = function() {
that.$notify({
title: '错误',
message: '服务器错误,无法接收实时报警信息',
type: 'error',
duration: 0
})
}
// socket
this.socket.onclose = function() {
console.log('WebSocket已关闭')
}
} }
},
init: function() {
this.timmer = setTimeout(() => {
sessionStorage.clear()
this.logout()
}, 1000 * 60 * 15) // 15分钟 https://blog.csdn.net/qq_42345108/article/details/103496456
},
logout() {
this.$store.dispatch('LogOut').then(() => {
location.reload()
})
} }
} }
} }

Loading…
Cancel
Save