微信小程序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>
相关推荐
我叫逢10 小时前
一键去水印实战已上线!心得~
微信小程序·php·去水印
qq_124987075313 小时前
基于微信小程序的电子元器件商城(源码+论文+部署+安装)
java·spring boot·spring·微信小程序·小程序·毕业设计
weixin_lynhgworld16 小时前
科技赋能医疗,陪诊小程序开启就医新体验
科技·小程序
2501_9160074717 小时前
iOS 证书如何创建,从能生成到能长期使用
android·macos·ios·小程序·uni-app·cocoa·iphone
壹立科技18 小时前
商超到家即时服务:软件基础功能打通“线上线下”关键链路
微信小程序·软件需求·外卖跑腿平台·外卖跑腿系统·商超配送
jqpwxt19 小时前
启点创新游乐场多商户分账管理系统:驱动文旅商业生态革新的数字化引擎
大数据·人工智能·小程序
00后程序员张20 小时前
AppStoreInfo.plist 在苹果上架流程中的生成方式和作用
android·小程序·https·uni-app·iphone·webview
计算机毕设指导620 小时前
基于微信小程序+django连锁火锅智慧餐饮管理系统【源码文末联系】
java·后端·python·mysql·微信小程序·小程序·django
风月歌20 小时前
php医院预约挂号系统小程序源代码(源码+文档+数据库)
数据库·微信小程序·小程序·毕业设计·php·源码
qq_12498707531 天前
基于微信小程序的校园资讯共享平台的设计与实现(源码+论文+部署+安装)
spring boot·后端·微信小程序·小程序·毕业设计