【重写 CryptoJS】二、WordArray 与位操作

本文介绍CryptoJS中的WordArray类,它是进行位操作的基础,用于抽象连续比特序列。WordArray拥有words和sigBytes两个成员,words是32位整数数组,sigBytes表示有效字节数。文章详细解析了WordArray的clamp方法、concat方法以及toString方法,展示了如何处理比特序列。同时,还讨论了clone方法和生成随机WordArray的方法。
摘要由CSDN通过智能技术生成

源码地址:entronad/crypto-es

 

【重写 CryptoJS】一、ECMAScript 类与继承

我们常见的各种编码、散列、加密算法,其基础都是位操作。

不管是对哪种数据类型,位操作对象的本质都是一段连续的比特序列。从性能的角度讲,位操作最好是能直接操作连续的内存位。很多语言提供了直接操作连续内存位的操作,比如 C++ 中的数组与指针,ECMAScript 6 中的 ArrayBuffer 。 JavaScript 最初是作为浏览器的脚本语言设计的,并没有直接操作内存的特性,但还是有办法获取到比特序列的抽象,那就是通过二进制位操作符( Binary Bitwise Operators )。

根据标准,在含有位操作符的运算中,不管是什么类型的操作数,都通过 ToInt32() 转换为 32 位有符号整数,然后将其当做 32 位的比特序列进行位运算,运算结果返回也为 32 位有符号整数。因此,通过拼接 32 位有符号整数,就可以实现“对一段连续的比特序列进行位操作”的功能了。

正是基于这样的原理, CryptoJs 实现了名为 WordArray 的类,作为“一段连续比特序列”的抽象进行各种位操作。 WordArray 是 CryptoJs 中最核心的一个类,所有主要算法的实际操作对象都是 WordArray 对象。理解 WordArray 是理解 CryptoJs 各算法的基础,也为今后使用 ArrayBuffer 重写的前提。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值