window.btoa() 遇到中文要出问题

localStorage.setItem("token",window.btoa(unescape(encodeURIComponent(UDATA["uid"]+"#START_AC#"+UDATA["uaccount"]+"#END_AC#"+"#START_TIME#"+time+"#END_TIME#"+"#START_SF#"+UDATA['usf']+"#END_SF#"))))

由于unescape过时了 就换一种写法,如下(下方的写法需要浏览器支持)

编码

const onFinish = values => {
console.log("values", values)
user_login(formState).then((res) => {
let code = res["code"]
let msg = res["message"]
notification.open({
message: '通知',
description: msg,
icon: () =>
h(SmileOutlined, {
style: 'color: #108ee9',
}),
});
if (code === 1) { console.log(res["data"])
let UDATA = res["data"] //账号状态判断
if (UDATA["status"] !== "正常") {
notification.open({
message: '通知',
description: "账号异常,已被停止使用,请联系管理员重试",
icon: () =>
h(SmileOutlined, {
style: 'color: #108ee9',
}),
});
return
} let time = parseInt(new Date().getTime() / 1000) + ''
localStorage.setItem("username", UDATA["uname"])
localStorage.setItem("account", UDATA["uaccount"])
// 拼接字符串
let dataString = UDATA["uid"] + "#START_AC#" + UDATA["uaccount"] + "#END_AC#" +
"#START_TIME#" + time + "#END_TIME#" +
"#START_SF#" + UDATA['usf'] + "#END_SF#"; // 使用 TextEncoder 进行 UTF-8 编码
const encoder = new TextEncoder();
const dataUint8Array = encoder.encode(dataString); // 将 Uint8Array 转换为 Base64
localStorage.setItem("token", btoa(Array.from(dataUint8Array, byte => String.fromCharCode(byte)).join('')));
router.push("/index")
}
})
};

关键代码

// 拼接字符串
let dataString = UDATA["uid"] + "#START_AC#" + UDATA["uaccount"] + "#END_AC#" +
"#START_TIME#" + time + "#END_TIME#" +
"#START_SF#" + UDATA['usf'] + "#END_SF#"; // 使用 TextEncoder 进行 UTF-8 编码
const encoder = new TextEncoder();
const dataUint8Array = encoder.encode(dataString); // 将 Uint8Array 转换为 Base64
localStorage.setItem("token", btoa(Array.from(dataUint8Array, byte => String.fromCharCode(byte)).join('')));

解码



onMounted(() => {
// 从本地存储获取 token
// 从 localStorage 中获取 Base64 编码的字符串
const token = localStorage.getItem("token"); if (token) {
try {
// 解码 base64 格式的 token // 使用 atob 函数将 Base64 字符串解码为二进制数据表示的字符串
const binaryString = atob(token); // 将二进制字符串转换回 Uint8Array
const dataUint8Array = Uint8Array.from(Array.from(binaryString, char => char.charCodeAt(0))); // 使用 TextDecoder 将 Uint8Array 解码回原始的 UTF-8 字符串
const decoder = new TextDecoder('utf-8');
const decodedString = decoder.decode(dataUint8Array); // 现在 decodedString 包含了原始的 dataString
console.log(decodedString);
let decodedToken = decodedString // 提取并验证 token 中的各个部分
const tokenParts = decodedToken.split("#START_TIME#")[1].split("#END_TIME#")[0];
const timestamp = parseInt(tokenParts, 10); // 总是指定 radix 为 10,避免潜在的安全问题 const tokenSF = decodedToken.split("#START_SF#")[1].split("#END_SF#")[0];
console.log("身份", tokenSF); // 检查 token 是否过期(以7天为期限)
const sevenDaysInSeconds = 7 * 24 * 60 * 60;
const currentTimestamp = parseInt(new Date().getTime() / 1000, 10); if ((currentTimestamp - timestamp) < sevenDaysInSeconds) {
console.log("自动登录!欢迎回来~");
// 这里可以继续进行其他自动登录后的操作
} else {
// 登录已过期,显示通知并跳转到登录页面
notification.open({
message: '通知',
description: "登录已过期,请重新登录。",
icon: () => h(SmileOutlined, {style: 'color: #108ee9'}),
});
localStorage.removeItem("token"); // 清除过期的 token
router.push("/login");
}
} catch (error) {
console.error("Error decoding token:", error);
// 处理错误:清除无效的 token 并跳转到登录页面
localStorage.removeItem("token");
router.push("/login");
}
} else {
// 如果没有 token,直接跳转到登录页面
router.push("/login");
}
});

关键代码

// 使用 atob 函数将 Base64 字符串解码为二进制数据表示的字符串
const binaryString = atob(token); // 将二进制字符串转换回 Uint8Array
const dataUint8Array = Uint8Array.from(Array.from(binaryString, char => char.charCodeAt(0))); // 使用 TextDecoder 将 Uint8Array 解码回原始的 UTF-8 字符串
const decoder = new TextDecoder('utf-8');
const decodedString = decoder.decode(dataUint8Array); // 现在 decodedString 包含了原始的 dataString
console.log(decodedString);

【前端】2024年 前端Base64编码的中文处理问题的更多相关文章

  1. PHP处理base64编码字符串

    接收前端传过来的base64编码后的字符串, 如果是json字符串, 那么PHP使用file_get_contents('php://input'); 来接收. 本次这里是以post传参的形式传bas ...

  2. base64编码的字符串(含有中文) 前端解码

    base64编码的字符串(含有中文) 前端解码 https://xue5602.github.io/2018/12/19/atob%E8%A7%A3%E7%A0%81utf-8%E5%AD%97%E7 ...

  3. 前端对base64编码的理解,原生js实现字符base64编码

    目录 常见对base64的认知(不完全正确) 多问一个为什么,base64到底是个啥? 按照我们的思路实现一下 到这里基本就实现了,结果跟原生的方法打印的是一样的 下一次 @( 对于前端工程师来说ba ...

  4. 【前端攻略】:玩转图片Base64编码

    引言 图片处理在前端工作中可谓占据了很重要的一壁江山.而图片的 base64 编码可能相对一些人而言比较陌生,本文不是从纯技术的角度去讨论图片的 base64 编码.标题略大,不过只是希望通过一些浅显 ...

  5. 【前端攻略】:玩转图片Base64编码(转)

    引言 图片处理在前端工作中可谓占据了很重要的一壁江山.而图片的Base64编码可能相对一些人而言比较陌生,本文不是从纯技术的角度去讨论图片的base64编码.标题略大,不过只是希望通过一些浅显的论述, ...

  6. 前端上传图片回显并用base64编码,后端做解码储存,存储图片路径在.properties文件中配置(以上传身份证照片为例)

    前端页面:<form id="kycForm" enctype="multipart/form-data"> <input type=&quo ...

  7. 前端上传 base64 编码图片到七牛云存储

    参考文档 如何上传base64编码图片到七牛云 调试过程 文档中分别有 java 和 html 的 demo,可以根据文档示例调试. 下面是我调试的过程,可以作为参考,特别注意的是,如果需要给文件起名 ...

  8. base64编码后的pdf文件前端页面展示--pdf.js的应用

    最近在整理项目中用到的插件或者使用心得,感觉还是写成博客,能加深新一层的理解. 我先说一下我的需求:由于java后台编译的文件流在手机端加载速度太慢,所以想着可以在前端解析,放在页面展示给用户. 所以 ...

  9. weui上传多图片,前端压缩,base64编码

    记录一下在做一个报修功能的心路历程,需求功能很简单,一个表单提交,表单包含简单的文字字段以及图片 因为使用的是weui框架,前面的话去找weui的表单和图片上传组件,说实话,weui的组件写的还不错, ...

  10. 前端 img标签显示 base64格式的 图片

    本文链接:https://blog.csdn.net/kukudehui/article/details/80409522在做项目的时候,我从后端返回了一个base64格式的图片文件,想把它渲染在前端 ...

随机推荐

  1. 【Wing】背后的插件们

    wing 作为我们日常开发的命令行开发工具,项目开源以来,陆陆续续接入了多个插件,在这里集中分享给大家. ☞ Github ☜ ☞ Gitee ☜ 01. wing -screen 作为Android ...

  2. auto` 作为返回值类型的一些限制

    在 C++ 中,auto 作为返回值类型有一些限制,这与类型推导的方式和时机有关. 虽然在很多场景下 auto 可以简化代码,但它不能直接用于函数返回类型,这是因为在编译时类型推导的机制不同于局部变量 ...

  3. USB gadget驱动框架(五)

    本节主要分析虚拟串口的tty设备的注册.创建/dev/ttyGSx设备节点.tty相关接口的实现. tty的申请与注册 源码:drivers/usb/gadget/function/u_serial. ...

  4. 对抗生成网络(GAN)简单介绍

    对抗生成网络主要由生成网络和判别网络构成,GAN在图像领域使用较多.利用生成网络生成假的图像,然后利用判别器是否能判断该图像是假的. 1.用于医学图像分割,一般我们可以利用一个U-Net网络生成分割结 ...

  5. Idea启动多服务时的Dashboard展示

    1.提换.idea/workspace.xml文件中的RunDashboard标签 <component name="RunDashboard"> <option ...

  6. (超全)Python汇总篇,200+Python标准库介绍

    关于Python标准库 众所周知,Python是一个依赖强大的组件库完成对应功能的语言,为了便捷实现各项功能,前辈大牛们打造了多种多样的工具库公开提供给大众使用,而越来越多的库已经因为使用的广泛和普遍 ...

  7. ToDesk云电脑实测!轻松应对游戏电竞、AIGC创作、设计建模等场景

    万物智联时代,现代社会对数字计算的需求呈指数级增长.当算力成为推动技术创新和应用发展的重要引擎,云电脑产业正在悄然占据国内算力应用的市场,成为新时代的数字经济发展方向.1 云电脑,顾名思义,是一台随时 ...

  8. 解决ros-melodic-desktop-full安装过程中未满足的依赖关系问题

    sudo apt install ros-melodic-desktop-full 正在读取软件包列表- 完成正在分析软件包的依赖关系树 正在读取状态信息- 完成 有一些软件包无法被安装.如果您用的是 ...

  9. 一些常用的jQuery方法1_20220128

    1.jQuery.merge()方法 $.merge() 函数用于合并两个数组内容到第一个数组.*$*.merge( first, second ) $(function () { var arr = ...

  10. DOS下的网络管理命令

    DOS下的网络管理命令 一. 实验目的 掌握DOS下的网络管理命令 二. 实验内容和要求 在DOS环境下用不同的网络管理命令,实现不同的网络管理功能 三. 实验方法.步骤及结果测试 1.  原理分析及 ...