Base16加密算法
Base16编码使用16个ASCII可打印字符(数字0-9和字母A-F)对任意字节数据进行编码。
Base16先获取输入字符串每个字节的二进制值(不足8比特在高位补0),然后将其串联进来
再按照4比特一组进行切分,将每组二进制数分别转换成十进制
然后在下面找到对应的编码串接起来就是Base16编码。
编码 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
字符 0 1 2 3 4 5 6 7 8 9 A B C D E F
可以看到8比特数据按照4比特切分刚好是两组,所以Base16
不可能用到填充符号“=”。
Base16编码后的数据量是原数据的两倍:
1000比特数据需要250个字符(即 250*8=2000 比特)。
换句话说:Base16使用两个ASCII字符去编码原数据中的一个字节数据。
上面是原理,下面是操作
- 第一步,先使用Java代码取出字节数组
比如说“你好”: -28 -67 -96 -27 -91 -67
byte[] bytes = "你好".getBytes();
第二步,获取每个字节的二进制,不足8 Bit在高位补0
换言之就是将字节数组中的数据分别与255(0xFF)进行与运算,得出的结果就是数字的32位二进制的后八位
比如:
-28 ==> 11111111111111111111111111100100 & 255 ==> 00000000000000000000000011111111-------------------------------------------------228 ==> 000000000000000000000000`11100100`
这样就得到了后八位11100100
short lastEight = (short) (aByte & 0xFF);
如果需要口算,下面规则即可:
正数 & 255 = 正数 % 256
负数 & 255 = 255 + 负数
所以上述的字节计算出结果为:
228 189 160 229 165 189
二进制为:
11100100 10111101 10100000 11100101 10100101 10111101
第三步,按照4比特一组进行切分,将每组二进制数分别转换成十进制
拆分方法:- 高4位的方法:
二进制数字 >> 4
比如说:
228 ==> 11100100
228 >> 4 ==> 1110就得到了高4位
short boforeFour = (short) (lastEight >> 4);
- 低4位的方法:参照第二步取出后八位的方法取出后四位
比如说:
228 ==> 11100100
228 & 0xF = 0100就得到了低4位
short lastFour = (short) (lastEight & 0xF);
- 二进制的4 bit拆分为:
1110 0100 1011 1101 1010 0000 1110 0101 1010 0101 1011 1101
对应的10进制为:
14 4 11 13 10 0 14 5 10 5 11 13
- 高4位的方法:
第四步,对照码表
14 4 11 13 10 0 14 5 10 5 11 13E 4 B D A 0 E 5 A 5 B D
所以最后的编码为:E4BDA0E5A5BD
Base16加密算法相关推荐
- 【2021.12.25】ctf逆向中常见加密算法和编码识别
[2021.12.25]ctf逆向中常见加密算法和编码识别(含exe及wp) 文章目录 [2021.12.25]ctf逆向中常见加密算法和编码识别(含exe及wp) 0.前言 1.基础加密手法 2.b ...
- RSA、MD5等加密算法的区别和应用
RSA算法: 是典型的非对称加密算法,主要具有数字签名和验签的功能. MD5算法: 是消息摘要算法,只能用来生成消息摘要无法进行数字签名. IDEA算法和RC4算法: 对称加密算法,只能用来进行数据加 ...
- SQL Server 数据库中的 MD5 和 SHA1加密算法
MD5 和 SHA1 是一种单向加密算法,常用于密码的验证等需要加密操作的场合,在一般情况下,开发人员可以通过 Delphi 或 PHP 这类语言自己编写相关函数或者使用自带的函数,然后将加密过的结果 ...
- 对称加密算法AES之GCM模式简介及在OpenSSL中使用举例
AES(Advanced Encryption Standard)即高级加密标准,由美国国家标准和技术协会(NIST)于2000年公布,它是一种对称加密算法.关于AES的更多介绍可以参考:https: ...
- 非对称加密算法RSA公钥私钥的模数和指数提取方法
生成非对称加密算法RSA公钥.私钥的方法: 1. 通过OpenSSL库生成,可参考 https://github.com/fengbingchun/OpenSSL_Test/blob/master/ ...
- 非对称加密算法之RSA介绍及OpenSSL中RSA常用函数使用举例
RSA算法,在1977年由Ron Rivest.Adi Shamirh和LenAdleman,在美国的麻省理工学院开发完成.这个算法的名字,来源于三位开发者的名字.RSA已经成为公钥数据加密标准. R ...
- 对称加密算法之RC4介绍及OpenSSL中RC4常用函数使用举例
RC4是一种对称密码算法,它属于对称密码算法中的序列密码(streamcipher,也称为流密码),它是可变密钥长度,面向字节操作的流密码. RC4是流密码streamcipher中的一种,为序列密码 ...
- 对称加密算法之DES介绍
DES(Data Encryption Standard)是分组对称密码算法.DES采用了64位的分组长度和56位的密钥长度,它将64位的输入经过一系列变换得到64位的输出.解密则使用了相 ...
- java aes php_php和java的aes默认加密算法有点区别及解决方法。
1.php和java的aes默认加密算法有点区别,php能解密java加密的密文,但java不能解密php加密的密文.原因在于: 1.Java中AES加密与解密默认使用AES/ECB/PKCS5Pad ...
- iOS,Android,WP, .NET通用AES加密算法
这两天为移动App开发API,结果实现加密验证时碰到一大坑.这里不得不吐槽下又臭又硬的iOS,Windows Server无法解密出正确的结果,Android则可以,后来使用了通用的AES256加密算 ...
最新文章
- Error:(23, 25) 错误: 程序包R不存在
- DIY穷人版谷歌眼镜,自定义手势操控,树莓派再一次被开发新玩法
- (转)常用正则表达式
- 如何通过httpd和DVD ISO在RHEL上配置yum本地源
- 生活就是要开“新”,攀升电脑陪你一起大胆想象
- 信安教程第二版-第19章操作系统安全保护
- 更新mysql软件_MySQL软件升级
- 【CCCC】L3-003 社交集群 (30分),并查集模板,map排序
- 甲骨文裁员后续:近万招聘者哄抢甲骨文前员工
- 坑爹的RockSaw和坑爹的windows7
- qq拼音输入法下载|qq拼音输入法纯净版下载
- 汤国安《地理信息系统教程》(第二版)笔记(1)——概论
- 西数推出首款SanDisk驱动器:蓝盘和绿盘
- 刷新bios后电脑死机了怎么办
- XGBOOST与GBD区别笔记
- workman php 安装,windows 安装workman本地快速入门
- flink实战--核心概念解析和应用
- GDI+ 制作透明图片
- 关于罗德里格斯公式(Rodrigues‘sFormula)的详细推导过程
- 适合安装在服务器上使用的操作系统,适合于做服务器的操作系统有