微信小程序base64与十六进制相互转换(使用btoa、atob方法报undefined)
2023-12-13 03:34:01
前言:搜到很多方法都用到了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>
文章来源:https://blog.csdn.net/Dalin0929/article/details/134830308
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!