|
JML | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectnet.sf.jqql.Crypter
public class Crypter
加密解密QQ消息的工具类. QQ消息的加密算法是一个16次的迭代过程,并且是反馈的,每一个加密单元是8字节,输出也是8字节,密钥是16字节 我们以prePlain表示前一个明文块,plain表示当前明文块,crypt表示当前明文块加密得到的密文块,preCrypt表示前一个密文块 f表示加密算法,d表示解密算法 那么从plain得到crypt的过程是: crypt = f(plain ˆ preCrypt) ˆ prePlain 所以,从crypt得到plain的过程自然是 plain = d(crypt ˆ prePlain) ˆ preCrypt 此外,算法有它的填充机制,其会在明文前和明文后分别填充一定的字节数,以保证明文长度是8字节的倍数 填充的字节数与原始明文长度有关,填充的方法是:
------- 消息填充算法 -----------
a = (明文长度 + 10) mod 8
if(a 不等于 0) a = 8 - a;
b = 随机数 & 0xF8 | a; 这个的作用是把a的值保存了下来
plain[0] = b; 然后把b做为明文的第0个字节,这样第0个字节就保存了a的信息,这个信息在解密时就要用来找到真正明文的起始位置
plain[1 至 a+2] = 随机数 & 0xFF; 这里用随机数填充明文的第1到第a+2个字节
plain[a+3 至 a+3+明文长度-1] = 明文; 从a+3字节开始才是真正的明文
plain[a+3+明文长度, 最后] = 0; 在最后,填充0,填充到总长度为8的整数为止。到此为止,结束了,这就是最后得到的要加密的明文内容
------- 消息填充算法 ------------
Constructor Summary | |
---|---|
Crypter()
constructor 构造函数 |
Method Summary | |
---|---|
byte[] |
decrypt(byte[] in,
byte[] k)
|
byte[] |
decrypt(byte[] in,
int offset,
int len,
byte[] k)
解密 |
byte[] |
encrypt(byte[] in,
byte[] k)
|
byte[] |
encrypt(byte[] in,
int offset,
int len,
byte[] k)
加密 |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public Crypter()
Method Detail |
---|
public byte[] decrypt(byte[] in, int offset, int len, byte[] k)
in
- 密文offset
- 密文开始的位置len
- 密文长度k
- 密钥
public byte[] decrypt(byte[] in, byte[] k)
in
- 需要被解密的密文inLen
- 密文长度k
- 密钥
public byte[] encrypt(byte[] in, int offset, int len, byte[] k)
in
- 明文字节数组offset
- 开始加密的偏移len
- 加密长度k
- 密钥
public byte[] encrypt(byte[] in, byte[] k)
in
- 需要加密的明文inLen
- 明文长度k
- 密钥
|
JML | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |