diff --git a/src/App.vue b/src/App.vue index 5d191f7..6477526 100644 --- a/src/App.vue +++ b/src/App.vue @@ -18,12 +18,19 @@ this.versionReload() }, mounted() { + // 页面加载时标记为"活动状态" - rqrq + sessionStorage.setItem('page_active', 'true') + // 监听浏览器关闭事件,自动退出登录 - rqrq window.addEventListener('beforeunload', this.handleBeforeUnload) + + // 监听页面显示事件(从缓存恢复或刷新后) - rqrq + window.addEventListener('pageshow', this.handlePageShow) }, beforeDestroy() { // 移除事件监听 - rqrq window.removeEventListener('beforeunload', this.handleBeforeUnload) + window.removeEventListener('pageshow', this.handlePageShow) }, methods: { versionReload(){ @@ -37,14 +44,29 @@ location.reload(); } }, + // 页面显示时(刷新后)恢复活动状态 - rqrq + handlePageShow() { + sessionStorage.setItem('page_active', 'true') + }, // 浏览器关闭时自动退出登录 - rqrq - handleBeforeUnload() { - const token = this.$cookie.get('token') - if (token && token.trim()) { - // 使用 sendBeacon 发送退出请求,可靠性高 - rqrq - const url = this.$http.adornUrl('/sys/logout') - navigator.sendBeacon(url, new Blob([JSON.stringify({ token })], { type: 'application/json' })) - } + handleBeforeUnload(e) { + // 标记为"即将卸载"状态 - rqrq + sessionStorage.setItem('page_active', 'false') + + // 延迟50ms检查是否是真正关闭(而不是刷新)- rqrq + setTimeout(() => { + const pageActive = sessionStorage.getItem('page_active') + // 如果50ms后仍然是false,说明是真正关闭,执行退出登录 - rqrq + if (pageActive === 'false') { + const token = this.$cookie.get('token') + if (token && token.trim()) { + // 使用 sendBeacon 发送退出请求,可靠性高 - rqrq + const url = this.$http.adornUrl('/sys/logout') + navigator.sendBeacon(url, new Blob([JSON.stringify({ token })], { type: 'application/json' })) + console.log('检测到浏览器/标签页关闭,已自动退出登录 - rqrq') + } + } + }, 50) } } }