微信小程序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 字符串

javascript 复制代码
<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>
相关推荐
灵机一物14 小时前
灵机一物AI原生电商小程序(已上线)-从“48 小时失联”到“长期可触达”:一套小程序公众号关注引导 + 订阅消息授权的产品化设计
小程序
碎像14 小时前
掌握uniapp发布微信小程序、App(Android)
微信小程序·小程序·uni-app
宠友信息14 小时前
社交软件源码哪个渠道好
java·微服务·架构·社交电子·springboot·uniapp
程序媛徐师姐15 小时前
Java基于SSM的实验室管理微信小程序,附源码+文档说明
java·微信小程序·实验室管理·实验室管理微信小程序·java实验室管理微信小程序·java实验室管理小程序·实验室管理小程序
CHU7290351 天前
生鲜团购商城小程序:新鲜触手可及的便捷购物新体验
小程序
医疗信息化王工2 天前
钉钉小程序开发实战:手术查询小程序
小程序·钉钉·手术查询
Fate_I_C2 天前
uniappx 鸿蒙运行包制作失败
华为·uni-app·uniapp·harmonyos
软件开发技术2 天前
新版点微同城主题源码34.7+全套插件+小程序前后端 源文件
小程序·php
mon_star°2 天前
消防安全培训小程序项目亮点与功能清单
小程序
自然 醒2 天前
uni-app开发微信小程序,如何使用towxml去渲染md格式和html标签格式的内容?
微信小程序·uni-app·html