位置: 编程技术 - 正文

JavaScript实现Base64编码转换

发布时间:2024-02-27

推荐整理分享JavaScript实现Base64编码转换,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

简介

Base是一种基于个可打印字符来表示二进制数据的表示方法。由于2的6次方等于,所以每6个比特为一个单元,对应某个可打印字符。三个字节有个比特,对应于4个Base单元,即3个字节需要用4个可打印字符来表示。它可用来作为电子邮件的传输编码。在Base中的可打印字符包括字母A-Z、a-z、数字0-9,这样共有个字符,此外的两个可打印符号在不同的系统中而不同,一般为+和/。

转换原理

Base的直接数据源是二进制序列(Binary Sequence)。当然,你也可以将图片、文本和音视频转换成二进制序列,再然后转换为Base编码。我们这里讨论的是如何将二进制转换为Base编码,对于如何将图片,文本和音视频转换为二进制序列敬请期待。

在转换前,先定义一张索引表,这张表规定了如何转换:

转换的时候我们先将二进制序列分组,每6个比特为一组。但是如果编码的字节数不能被3整除,那么最后就会多出1个或两个字节,可以使用下面的方法进行处理:先使用0字节值在末尾补足,使其能够被3整除,然后再进行base的编码。在编码后的base文本后加上一个或两个'='号,代表补足的字节数。也就是说,当最后剩余一个八位字节(一个byte)时,最后一个6位的base字节块有四位是0值,最后附加上两个等号;如果最后剩余两个八位字节(2个byte)时,最后一个6位的base字节块有两位是0值,最后附加一个等号。 参考下表:

JavaScript实现Base

JavaScript实现Base64编码转换

原理明白了以后,实现起来就很容易了。

将图片数据进行Base编码

将图片数据转换为Base,首先要获取到图片的二进制数据。图片的二进制数据可以通过canvas接口得到。具体实现为:

取到图片的二进制数据后,接下来就要进行编码了。因为图片不仅包含像素信息,还包含长度,宽度信息。所以在编码像素信息的同时也应将宽度和高度信息按某一约定进行编码,我是这样处理的:

将图片的像素数值数据转换为二进制序列;将宽度和高度信息组合成字符串 $$width,height$$,转换为二进制序列;将图片像素信息的二进制序列和图片宽高度的二进制序列组合起来,然后再进行Base的编码

具体实现为:

将图片Base数据进行解码

解码是编码的逆过程。过程大致为:

将图片的Base信息进行解码,得到包含图片像素信息和宽高度信息的二进制序列;然后将这个二进制序列解码成字符串,获取高度和宽度信息;去除二进制序列中的高度和宽度信息,得到像素信息;根据像素信息生成像素矩阵;根据像素矩阵、宽度和高度创建图片对象ImageData;利用putImageData将图像绘制出来。

具体的代码实现为:

javascript断点调试心得分享 1.断点调试是啥?难不难?断点调试其实并不是多么复杂的一件事,简单的理解无外呼就是打开浏览器,打开sources找到js文件,在行号上点一下罢了。操

Bootstrap每天必学之导航组件 在bootstrap框架中将导航独立出来成为一个导航组件,根据不同的版本,可以找到相应的源码:LESS:navs.lessSASS:_navs.scss标签形导航,也称选项卡导航标签形

下雪了 javascript实现雪花飞舞 本文实例为大家分享了雪花飞舞效果javascript实现,供大家参考,具体内容如下原理:1、js动态创建DIV,指定CLASS类设置不同的背景图样式显示不同的雪花效

标签: JavaScript实现Base64编码转换

本文链接地址:https://www.jiuchutong.com/biancheng/373505.html 转载请保留说明!

上一篇:JS验证逗号隔开可以是中文字母数字(js 验证数字)

下一篇:javascript断点调试心得分享(js中断点用法)

  • 拟上市企业需要做什么
  • 所得税禁止扣除项目
  • 办公室购买清洁剂
  • 收到社保局返还的应届毕业生补贴
  • 土地使用税怎么终止
  • 无形资产减值是否可以转回
  • 支付职工医药费计入什么科目
  • 主营业务收入如何红冲
  • 记账汇率是什么意思
  • 中国银行结算包括哪些内容?怎么做会计分录?
  • 私车公用保险费用公司承担吗
  • 停车费要交税吗
  • 机械租赁费发票图片
  • 增值税普通发票税率
  • 金税三期理解
  • 金融业融资租赁
  • 2019年水利部
  • 个人取得下列各项所得须自行申报纳税的有
  • 软件许可协议是什么意思
  • 增值税计算方法有哪些
  • 上个月个税申报能作废重报吗
  • 商业企业向供货方收取的返还收入
  • 会计新手入门
  • 审计查出假发票怎么补救
  • 期初建账分录
  • 网络平台上进行网络营销
  • 系统之家装机可靠吗
  • macbookair邮件
  • 不良修复体的危害
  • 增值税纳税申报首先要稽核比对
  • 手把手怎么样
  • .sfx.exe是什么文件
  • PHP:imageloadfont()的用法_GD库图像处理函数
  • php各个框架的优缺点
  • 正则表达式在线生成器
  • 搜索人工制造
  • 税款入库期是什么意思
  • ICLR‘23 UnderReview | LightGCL: 简单而有效的图对比学习推荐系统
  • 期初成本和期末成本
  • python单链表的创建
  • 利息收入的纳税调整
  • 开收据可以列收入吗
  • php框架 hyperf
  • mysql使用ssl连接
  • python中变量类型有几种
  • 核定征收企业注册
  • 担保公司的风险准备金在报表中如何反应
  • 企业收到海河工厂发运的乙材料,并验收入库
  • 财务报表漏报了会影响领票吗
  • 生产成本和营业成本的区别和联系
  • 存单丢失了,去哪里挂失
  • 外地预缴怎么算
  • 财付通支付的优缺点
  • 缴纳房产税和城镇房产税
  • 转帐支票遗失怎么办
  • 日用品增值税率是多少
  • 企业搬迁补偿款免税的法律依据是什么
  • centos6.7安装图形界面教程
  • win10桌面上图标
  • os x 10.11 el capitan中文版上手体验评测
  • g++.exe error
  • linux扫描硬件
  • linux中的top命令
  • windows 8开机
  • js require()
  • js 编辑框
  • cocos creator 优化 drawcall 合并
  • opengl教学视频
  • Unity3D游戏开发基础
  • javascript提交数据
  • python科学绘图
  • unity unit
  • ubuntu14重置密码
  • vue异步加载第三方库
  • android图形架构
  • jquery判断是否有某个class
  • js怎么获取密码框内容
  • js复制字符串的方法
  • 广告业发票税率是多少 可以抵扣多少
  • 地税注销流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号