md.getmd5s("admin123");
md.getmd5s("");
准备去调用
public void getmd5s(String ss) throws NoSuchAlgorithmException {
MessageDigest md5 = MessageDigest.getInstance("MD5");
String salt="saltstr";
md5.update((ss+salt).getBytes());
byte[] digest = md5.digest();
ByteString b1 = ByteString.of(digest);
String b4 = b1.base64();
Log.d("加盐后",b4);
// 去主动调用这个md5,然后我们用空值,就可以得到这个盐粒。
// 解码开始
ByteString bs1 = ByteString.decodeBase64("/ZfTBIQ+eTq3O4JRRYUU4g==");
// ByteString bb2 = ByteString.of(bs1.toByteArray());
Log.d("解出来字节码是变成明文后就是",bs1.toString());
ByteString bs2 = ByteString.decodeBase64("sNGWCqoTIxvJqK0OSo1rTw==");
Log.d("md5利用空值套出盐出来",bs2.toString());
}
下面是一些md5常识性的东西
public String getmd5(String ss) throws NoSuchAlgorithmException {
MessageDigest md5 = MessageDigest.getInstance("MD5");
md5.update(ss.getBytes());//这个点意思就是不断压入数据,如果数据过大,只能不断压入。
md5.reset();
// 如果有以上那行代码就是擦出不要了
md5.update("umrumrumrumrumrumrumrumrrumr".getBytes(),3,5);//压入的时候,取第三个,的5个长度的字符串。
//也就是说传过来的ss是admin,那么就是admin+umrum
byte[] digest1 = md5.digest("rw".getBytes());
ByteString bs3 = ByteString.of(digest1);
//这一行就是最后压入rw,那么应该是admin+umrum+rw;
Log.d("测试压入是不是我们需要的md5",bs3.toString());
byte[] digest = md5.digest(ss.getBytes());//内存中的字节码出来了
ByteString bs = ByteString.of(digest);
String b4=bs.base64();
String hex=bs.hex();
byte[] bytes1=ByteString.decodeHex(hex).toByteArray();
// byte[] bytes2=ByteString.decodeBase64("ISMvKXpXpadDiUoOSoAfww==").toByteArray();
byte[] bytes2=ByteString.decodeBase64("ISMvKXpXpadDiUoOSoAfww==").toByteArray();
Log.d("hex解码",Arrays.toString(bytes1));
Log.d("base64解码",Arrays.toString(bytes2));
Log.d("转换base64",b4);
Log.d("转换hex",hex);
ByteString bs2 = ByteString.of(bytes2);//将字节码变成明文的作用。
Log.d("反向得出原来base64的Md5的值是什么",bs2.toString());
return "变成字节码:"+Arrays.toString(digest)+"自己码转换成md5成品"+bs.toString();
}