JS如何实现Base64编码和解码(及中文乱码问题)

 更新时间:2023年10月12日 10:52:00   作者:一颗不甘坠落的流星  
这篇文章主要给大家介绍了关于JS如何实现Base64编码和解码及中文乱码问题的相关资料,Base64编码是一种常用的将二进制数据转换为文本数据的方式,文中通过代码介绍的非常详细,需要的朋友可以参考下

一、原生实现

  • JavaScript 定义了两个与 Base64 相关的全局方法。

1. btoa():字符串或二进制值转为 Base64 编码。
2. atob():把 Base64 编码转为原来的字符。

  • 遇到中文编码需要先做一次 URI 组件编码或对解码后的内容进行 URI 解码

1. encodeURIComponent():结合 btoa 使用
2. decodeURIComponent():结合 atob 使用

  • 示例:Base64 编码
// btoa() 相当于 window.btoa(),encodeURIComponent 同理
const str = 'test'
const encode = btoa(encodeURIComponent(str))
console.log(encode)	// dGVzdA==
  • 示例:Base64 解码
// atob() 相当于 window.atob(),decodeURIComponent 同理
const str = 'dGVzdA=='
const decode = decodeURIComponent(atob(str))
console.log(decode)	// test
  • 中文乱码处理方法:
const Base64 = {
    encode(str) {
        // 首先,我们使用 encodeURIComponent 来获得百分比编码的UTF-8,然后我们将百分比编码转换为原始字节,最后存储到btoa里面
        return btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g,
            function toSolidBytes(match, p1) {
                return String.fromCharCode(Number('0x' + p1));
            }));
    },
    decode(str) {
        // 过程:从字节流到百分比编码,再到原始字符串
        return decodeURIComponent(atob(str).split('').map(function (c) {
            return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);
        }).join(''));
    }
}
let encoded = Base64.encode("一颗不甘坠落的流星"); 	// "5LiA6aKX5LiN55SY5Z2g6JC955qE5rWB5pif"
let decoded = Base64.decode(encoded); 				// "一颗不甘坠落的流星"

二、插件实现

  • 按照 Base64 插件:编解码:js-base64,判断是否是Base64编码格式:is-base64
npm i js-base64
npm i is-base64
  • 插件使用
import isBase64 from 'is-base64';
import { Base64 } from 'js-base64';
// 封装解码函数
const base64ToStr = (base64Str: string): string => {
  if (isBase64(base64Str)) {
    return Base64.decode(base64Str);
  }
  return base64Str;
};
// 封装编码函数
export const strToBase64 = (str: string): string => Base64.encode(str);
console.log(strToBase64('一颗不甘坠落的流星'))	// 5LiA6aKX5LiN55SY5Z2g6JC955qE5rWB5pif
console.log(base64ToStr('5LiA6aKX5LiN55SY5Z2g6JC955qE5rWB5pif'))	// 一颗不甘坠落的流星

总结 

到此这篇关于JS如何实现Base64编码和解码及中文乱码问题的文章就介绍到这了,更多相关JS Base64编码和解码内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JavaScript兼容浏览器FF/IE技巧

    JavaScript兼容浏览器FF/IE技巧

    本文给大家分享的是一个JavaScript兼容火狐浏览器与IE浏览器的一个小技巧,非常的简单实用,有需要的小伙伴可以参考下
    2016-08-08
  • javascript中alert()与console.log()的区别

    javascript中alert()与console.log()的区别

    我们在做js调试的时候使用 alert 可以显示信息,调试程序,alert 弹出窗口会中断程序, 如果要在循环中显示信息,手点击关闭窗口都累死。而且 alert 显示对象永远显示为[object ]。 自己写的 log 虽然可以显示一些 object 信息,但很多功能支持都没有 console 好
    2015-08-08
  • 设置点击文本框或图片弹出日历控件的实现代码

    设置点击文本框或图片弹出日历控件的实现代码

    下面小编就为大家带来一篇设置点击文本框或图片弹出日历控件的实现代码。小编觉得挺不错的,现在分享给大家,也给大家做个参考,一起跟随小编过来看看吧
    2016-05-05
  • 微信小程序实现下拉菜单切换效果

    微信小程序实现下拉菜单切换效果

    这篇文章主要为大家详细介绍了微信小程序实现下拉菜单切换效果,筛选条件功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-11-11
  • 微信小程序弹窗禁止页面滚动的实现代码

    微信小程序弹窗禁止页面滚动的实现代码

    这篇文章主要介绍了微信小程序弹窗禁止页面滚动的实现代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • electron实现图片的另存为功能

    electron实现图片的另存为功能

    本文主要介绍了在electron中如何实现图片的另存为操作,包括另存为按钮事件的编写,getImageType和saveAsPicture的主要代码,以及Electron进程与渲染进程的交互效果,希望能为使用electron的开发者提供帮助
    2024-10-10
  • Javascript循环绑定事件的示例代码

    Javascript循环绑定事件的示例代码

    我们先看一个关于Javascript利用循环绑定事件的例子
    2008-10-10
  • JavaScript

    JavaScript"模拟事件"的注意要点详解

    今天小编就为大家分享一篇关于JavaScript"模拟事件"的注意要点详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-02-02
  • JS 如何获取radio选中后的值及不选择取radio的值

    JS 如何获取radio选中后的值及不选择取radio的值

    获取radio选中后的值,这在提交页面经常会使用到的,在本文为大家介绍下不选择也能获取radio的值,具体实现如下,感兴趣的朋友可以参考下
    2013-10-10
  • 微信小程序排坑指南详解

    微信小程序排坑指南详解

    这篇文章主要为大家详细介绍了微信小程序排坑指南,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-05-05

最新评论