安卓逆向 -- 算法基础(MD5)
  KRe60ogUm4le 12天前 11 0

一、单向散列函数(消息摘要算法)

1、不管明文多长,散列后的密文定长

2、明文不一样,散列后结果一定不一样

3、散列后的密文不可逆

4、一般用于校验数据完整性、签名 sign

5、由于密文不可逆,所以后台无法还原,也就是说他要验证,会在后台以跟前台一样的方式去重新签名一遍。也就是说他会把源数据和签名后的值一起提交到后台。所以我们要保证在签名时候的数据和提交上去的源数据一致。这种算法特喜欢在内部加入时间戳,很多粗心的学员,通常会在签名的时候取一次时间戳,然后在提交源数据的时候,又取一次时间戳,导致后台验证失败。

6、常见算法

MD5

SHA1

SHA256

SHA512

HmacMD5

HmacSHA1

HmacSHA256

二、MD5算法

1、长度128个bit,32个十六进制字符、16个字节

2、Java版源码

String bs= "逆向有你a";
MessageDigest md=MessageDigest.getInstance("MD5");//我要用md5算法
md.update(bs.getBytes());//我要加密的数据
byte[] res = md.digest();//给我加密
System.out.println("MD5加密(字节):"+Arrays.toString(res));
System.out.println("MD5加密(字符串):"+bytes2HexString(res));
MessageDigest mdmd = MessageDigest.getInstance("MD5");
mdmd.update("逆向".getBytes(StandardCharsets.UTF_8));
mdmd.update("有你".getBytes(StandardCharsets.UTF_8));
byte[] mdmdres = mdmd.digest("a".getBytes(StandardCharsets.UTF_8));
System.out.println(bytes2HexString(mdmdres));
运行结果:
MD5加密(字节):[-71, 14, 97, 33, -121, -29, -25, 68, -80, 106, 94, 49, -21, -116, -13, 120]
MD5加密(字符串):B90E612187E3E744B06A5E31EB8CF378
B90E612187E3E744B06A5E31EB8CF378

3、JS版源码

var CryptoJS=module.exports;
function test()
{
return CryptoJS.MD5("逆向有你a").toString();
}
console.log(test());

运行结果:

安卓逆向 -- 算法基础(MD5)

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 12天前 0

暂无评论

推荐阅读
  KRe60ogUm4le   2024年03月22日   35   0   0 linux算法
  KRe60ogUm4le   12天前   17   0   0 递归算法
KRe60ogUm4le