auth.vue
1.83 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
<!--
* @Date: 2022-08-29 13:55:31
* @LastEditors: hookehuyr hookehuyr@gmail.com
* @LastEditTime: 2024-01-22 14:12:09
* @FilePath: /xysBooking/src/views/auth.vue
* @Description: 授权模块
-->
<template>
<div />
</template>
<script setup>
import { onMounted } from 'vue'
import { useRoute } from 'vue-router'
const $route = useRoute();
onMounted(() => {
// php需要先跳转链接获取openid
/**
* encodeURIComponent() 函数可把字符串作为 URI 组件进行编码。
* 该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。
* 其他字符(比如 :;/?:@&=+$,# 这些用于分隔 URI 组件的标点符号),都是由一个或多个十六进制的转义序列替换的。
*/
let raw_url = encodeURIComponent(location.origin + location.pathname + $route.query.href); // 未授权的地址
// 当用户完成授权后,使用 pushState() 方法将授权页面从浏览器历史记录中移除
let reload_url = import.meta.env.DEV
? '/'
: location.origin + location.pathname;
window.history.pushState(null, '', reload_url); // 将授权页面替换为根路径或其他合适的路径
// 在返回按钮被点击时,检测历史记录的变化并进行处理
// window.addEventListener('popstate', function(event) {
// // 检查当前页面的 URL
// if (window.location.pathname === '/auth') {
// // 如果当前页面是授权页面,使用 replaceState() 方法将其替换为其他页面
// window.history.replaceState(null, '', raw_url); // 替换为其他合适的路径
// }
// });
// TAG: 开发环境测试数据
const short_url = `/srv/?a=openid&res=${raw_url}`;
location.href = import.meta.env.DEV
? `${short_url}&test_openid=${import.meta.env.VITE_OPENID}`
: `${short_url}`;
})
</script>