位置: 编程技术 - 正文

JavaScript实现Base64编码转换

编辑:rootadmin

推荐整理分享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中断点用法)

  • 税务师考试需要记忆的税率
  • 偷税漏税逃税是什么意思
  • 小规模经营租赁开票税率
  • 房地产企业土地出让金抵减销项税额
  • 建筑公司购入的水泥等材料如果是做成本的怎么做分录
  • 足浴店装修费用多少
  • 有营业额有成本怎么算成本占比
  • 个税中房屋租赁日期写长跟写短
  • 企业转让固定资产使用权的收益应当属于
  • 税控技术维护费每年都能抵扣吗
  • 系统集成 税点
  • 减免房产税土地使用税 账务处理
  • 增值税的简易计税是什么意思
  • 单位投资非盈利性组织怎样核算
  • 税控盘抵减增值税需要结转吗
  • 实收资本未完全到账,需要缴纳印花税吗
  • 国家电网的发票如何申请邮寄
  • 什么情况下进项税额不得从销项税额中抵扣
  • 电梯安装简易征收的优点
  • 在建期间费用怎么处理?
  • 关于发票入账的会计分录
  • 一般纳税人具备的资格需要哪些条件
  • 财政部的监管职责范围不包括
  • 汇算清缴报错了怎么更正
  • 个税本期收入是应发还是实发
  • 展厅设计费用计什么科目
  • 哪里查询发票是否抵扣
  • 高新企业最新政策2020
  • 委托贷款利息收入怎么开发票
  • 一般纳税人简易计税会计分录
  • mac软件打开提示意外退出
  • 银行手续费会开发票吗
  • 会计管理制度范本
  • 我公司对某公司作如下措施
  • 出售报废固定资产的净损失计入什么科目
  • 账务和申报表不一致
  • php注册功能的实现
  • 笔记本电脑盖上盖子就关机了吗
  • 利息费用可扣除什么
  • Escarpment Trail in Porcupine Mountains Wilderness State Park, Michigan (© Pat & Chuck Blackley/Alamy)
  • 冰山从哪里来
  • 房地产开发成本明细
  • 未担保余值是谁承担
  • thinkphp6 数据库
  • 劳务费怎么做会计分裤
  • 收取包装物押金会计分录
  • 小规模纳税人免增值税的账务处理
  • 出纳收到现金会计分录
  • jvm jmm
  • 技术维护费可以全额抵扣吗
  • 全年一次性奖金税率表2023最新
  • 预收账款是负债还是资产
  • 购买电脑一次性计入费用吗合理吗
  • 长期股权投资中同一控制和非同一控制的区别
  • 土地测绘费计入开发间接费?
  • 应收账款管理应该收集哪些信息
  • 发票冲红如何做账红字发票需要给购买方吗
  • 电子汇票接收后怎么操作
  • 小规模纳税人如何缴纳企业所得税
  • 生产成本是费用要素吗
  • Linux下mysql 5.6.17 安装图文教程
  • qq远程协助点不动
  • os x10.11el capitan公测版下载地址(公测版计划注册教程)
  • win8怎么调亮度调节
  • win7系统如何配置ip地址
  • 电脑用户名怎么改
  • linux查看系统日志
  • android开发流程
  • unity3d4个脚本
  • javascript怎么弄
  • 游戏开发unity3d
  • javascript HTML5文件上传FileReader API
  • linux实现shell
  • js实现兼容性较好的方法
  • 在javascript中如何定义并调用函数
  • jquery 动态添加元素
  • jquery complete
  • 贵州网上税务大厅官网
  • 广东省哪里地方考中控证好
  • 安徽国家税务局电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设