微信小程序base64与十六进制相互转换(使用btoa、atob方法报undefined)

前言:搜到很多方法都用到了btoa()、atob(),这两个属于Window 对象,在浏览器端可以直接使用,但是在小程序里面使用会报undefined。看到uniapp和微信小程序官方文档都提供了下面两个api,就想着经过ArrayBuffer 对象转换一下。
uni.base64ToArrayBuffer(base64)、wx.base64ToArrayBuffer(base64)
将 Base64 字符串转成 ArrayBuffer 对象
uni.arrayBufferToBase64(arrayBuffer)、wx.arrayBufferToBase64(arrayBuffer)
将 ArrayBuffer 对象转成 Base64 字符串

<script>
	export default {
   
		onShow() {
   
			let str = 'ksPNPc/9opXh3S7DBF+tJMvB3ybDtVjuip327aoYkrGEX3JXI1FxcbI4Fn/rScqgRdXwfUYyLK3yL2AQdHPelJWzx4u7xfj4JpfWag9lkaZubQnI3w9QqKtb9Dqwl771jqut8MJL338A8Zh7buOh9DXBNi1CZBGVVUN5zqmd/IyyhYo1CWyaFSGsaYSO7+xsEswQg8n2vLM6m7yFqL70/pV4eIsKtj5VDoTYphPanFEssWNt9Do4+cL6EUTQKC2XhrEeoZBI7iRWDzde3qzdwFPwUnb2Uxyo9E9Qg+CFvxtfFcB6D9G5+Nh9bbL6RfWgvmXgTxDqfl2Ynf4BWP6m1A=='
			let _hex = this.base64ToHex(str);
			console.log(this.hexToBase64(_hex) === str); // true
		},
		methods: {
   
			// base64转为十六进制
			base64ToHex(str) {
   
				const buffer = uni.base64ToArrayBuffer(str);
				// 或:const buffer = wx.base64ToArrayBuffer(str);
				return Array.prototype.map.call(new Uint8Array(buffer), x => ('00' +
					x.toString(16)).slice(-2)).join('');
			},
			// 十六进制转为base64
			hexToBase64(str) {
   
				const uint8Array = new Uint8Array(str.match(/.{1,2}/g).map(byte => parseInt(byte, 16)));
				return uni.arrayBufferToBase64(uint8Array);
				// 或:return wx.arrayBufferToBase64(uint8Array);
			}
		}
	}
</script>

最近更新

  1. TCP协议是安全的吗?

    2023-12-09 18:00:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-09 18:00:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-09 18:00:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-09 18:00:02       18 阅读

热门阅读

  1. 层三交换机解析(Layer 3 Switch)层3交换机

    2023-12-09 18:00:02       34 阅读
  2. 【npm】npm中classnames包是干嘛的

    2023-12-09 18:00:02       36 阅读
  3. CVE-2002-20001处理方法

    2023-12-09 18:00:02       38 阅读
  4. Oracle数组循环表存在则删除

    2023-12-09 18:00:02       43 阅读
  5. Linux常用命令

    2023-12-09 18:00:02       32 阅读
  6. MySQL:drop、delete与truncate区别

    2023-12-09 18:00:02       35 阅读
  7. 前后端分离项目跨域请求

    2023-12-09 18:00:02       33 阅读
  8. 小红书引流攻略:掌握策略,轻松吸引潜在客户

    2023-12-09 18:00:02       41 阅读
  9. 【C++】指针与new的使用

    2023-12-09 18:00:02       29 阅读
  10. 如何正确看待钱?

    2023-12-09 18:00:02       39 阅读