我正在尝试使用MessageDigest生成MD5总和。我有以下代码。
byte[] md5sum = digest.digest();
BigInteger bigInt = new BigInteger(1, md5sum);
output = bigInt.toString(16);
这不会返回32个字符串,而是一个31个字符串 8611c0b0832bce5a19ceee626a403a7
预期的字符串是 08611c0b0832bce5a19ceee626a403a7
输出中缺少前导0。
我尝试了另一种方法
byte[] md5sum = digest.digest();
output = new String(Hex.encodeHex(md5sum));
和输出是预期的。
我检查了文档,然后Integer.toString根据它进行转换
使用Character.forDigit提供的数字到字符的映射,并在适当时添加减号。
在Character.forDigit方法中
如果0 <= digit <基数,则digit参数有效。
有人可以告诉我两种方法有何不同,为什么删除前导0?
我个人将 避免 使用BigInteger
将二进制数据转换为文本的方法。即使 可以
使用它,它也不是真正的目的。有大量代码可用于将a转换byte[]
为其十六进制表示形式-例如,使用Apache Commons
Codec
或简单的单个方法:
private static final char[] HEX_DIGITS = "0123456789ABCDEF".toCharArray();
public static String toHex(byte[] data) {
char[] chars = new char[data.length * 2];
for (int i = 0; i < data.length; i++) {
chars[i * 2] = HEX_DIGITS[(data[i] >> 4) & 0xf];
chars[i * 2 + 1] = HEX_DIGITS[data[i] & 0xf];
}
return new String(chars);
}
我正在尝试使用MessageDigest生成MD5 sum。我有以下代码。 它返回的不是32个字符的字符串,而是31个字符的字符串 预期的字符串是 输出中缺少前导0。 我试过另一种方法 并且输出和预期的一样。 我检查了文档,我nteger.toString根据它进行转换 字符提供的数字到字符的映射。使用forDigit,如果合适,在前面加一个减号。 在性格上。数字方法 如果0,则数字参数有效 有人
问题内容: 我想删除十进制数字中的前导零。 所以我想输出应该是 没有 。我尝试过不工作,我也尝试过正则表达式!没有结果!是的,我正在使用BigDecimal。 问题答案: 试试这个
问题内容: 我有一个以许多空格开头的文本字符串,介于2和4之间。 删除前导空格的最简单方法是什么?(即删除某个字符之前的所有内容?) 问题答案: 该方法将删除以字符串开头的前导空格,换行符和制表符: 编辑 正如balpha在注释中指出的那样,为了 仅从 字符串开头删除空格,应使用:
本文向大家介绍Oracle删除archivelog文件的正确方法,包括了Oracle删除archivelog文件的正确方法的使用技巧和注意事项,需要的朋友参考一下 Oracle在开启了归档模式后,会在指定的archive目录下产生很多的archivelog文件,而且默认是不会定期清除的,时间长久了,该文件夹会占用很大的空间。 问题:如何定期正确删除archivelog文件呢? 很多人直接在arch
问题内容: 我很难尝试将.strip与以下代码行结合使用。 谢谢您的帮助。 问题答案: 您可以使用strip()删除尾随和前导空格。 注意:内部空间被保留
用EraseMode属性适合于画面变化最小的简单图的长序列。这里有一个例子放映模拟的布朗运动。指定点的数目,例如 n = 20 以及温度或速度,例如 s = .02 这两个参数的最佳值决定于你的计算机的速度。生成n个随机点,其(x,y)坐标介乎-1/2和+1/2。 x = rand(n,1)-0.5; y = rand(n,1)-0.5; 在边界为-1和1的正方形作出各点。保存点的向量的句柄