应用
KISS原则:
> SHA只是一个字符串
> String的JDK哈希码是“随机的”
>整数可以在任何基础上渲染
这一行代码就是这样的:
public static String shortHash(String sha) {
return Integer.toString(sha.hashCode() & 0x7FFFFFFF, 36).substring(0, 3);
}
注意:& 0x7FFFFFFF将符号位置零(哈希码可以是负数,否则将使用前导减号进行渲染).
编辑 – 保证哈希长度
我的原始解决方案是天真的 – 当int哈希小于100(基数36)时它没有处理这种情况 – 这意味着它将打印少于3个字符.此代码修复了这一点,同时仍保持值“随机”.它还避免了substring()调用,因此性能应该更好.
static int min = Integer.parseInt("100", 36);
static int range = Integer.parseInt("zzz", 36) - min;
public static String shortHash(String sha) {
return Integer.toString(min + (sha.hashCode() & 0x7FFFFFFF) % range, 36);
}
此代码通过强制它在100和zzz之间保证最终散列有3个字符 – 基数36中的最低和最高3字符散列,同时仍然使其“随机”.