答案 0 :(得分:1)
你可以试试的一种方式。
进行12位二进制显示,应该能够用5个字节表示。使用base64对其进行编码,它应该能够用9个字母数字字符表示。 (确定... base64确实包含几个非字母数字字符...:P)
(如果您在使用5字节表示时遇到困难,将12位数分成3组4位数,每个代表2个字节也应该有效)
搜索base64并了解它,然后您可以以类似的方式实现自己的编码方法。
添加一些代码: (没有经过测试,只是给你一个关于它的想法)
String originalId= "123456789012";
String resultString = new String(Base64.encodeBase64(new BigInteger(originalId).toByteArray());
答案 1 :(得分:0)
原始答案建议使用BigInteger,基数为36,但对于19位数字来说这还不够。
我不知道是否有可以转换为/来自base 62的库,但是下面的设计示例让您了解如何做到这一点。输出是:
originalId = 999999999999999999
newId = bUI6zOLZTrh
retrieveOriginalId = 999999999999999999
使用base 62的基本原理如下:
N ^ 11
11个字符数字(例如,在基数10中,11位数字可以在0到10 ^ 11或1000亿之间)示例代码(受BigInteger和Long类启发的算法 - 要添加的异常处理):
class Base62 {
private static final BigInteger RADIX = BigInteger.valueOf(62);
private static final char[] DIGITS = {
'0', '1', '2', '3', '4', '5',
'6', '7', '8', '9', 'a', 'b',
'c', 'd', 'e', 'f', 'g', 'h',
'i', 'j', 'k', 'l', 'm', 'n',
'o', 'p', 'q', 'r', 's', 't',
'u', 'v', 'w', 'x', 'y', 'z',
'A', 'B', 'C', 'D', 'E', 'F',
'G', 'H', 'I', 'J', 'K', 'L',
'M', 'N', 'O', 'P', 'Q', 'R',
'S', 'T', 'U', 'V', 'W', 'X',
'Y', 'Z'
};
public static void main(String[] args) throws IOException {
String originalId = "999999999999999999";
System.out.println("originalId = " + originalId);
String newId = getBase62From10(originalId);
System.out.println("newId = " + newId);
String retrieveOriginalId = getBase10From62(newId);
System.out.println("retrieveOriginalId = " + retrieveOriginalId);
}
/**
*
* @param number a positive number in base 10
*
* @return the same number, in base 62
*/
public static String getBase62From10(String number) {
char[] buf = new char[number.length()];
int charPos = number.length() - 1;
BigInteger i = new BigInteger(number);
BigInteger radix = BigInteger.valueOf(62);
while (i.compareTo(radix) >= 0) {
buf[charPos--] = DIGITS[i.mod(radix).intValue()];
i = i.divide(radix);
}
buf[charPos] = DIGITS[i.intValue()];
return new String(buf, charPos, (number.length() - charPos));
}
/**
*
* @param number a positive number in base 62
*
* @return the same number, in base 10
*/
public static String getBase10From62(String number) {
BigInteger value = BigInteger.ZERO;
for (char c : number.toCharArray()) {
value = value.multiply(RADIX);
if ('0' <= c && c <= '9') {
value = value.add(BigInteger.valueOf(c - '0'));
}
if ('a' <= c && c <= 'z') {
value = value.add(BigInteger.valueOf(c - 'a' + 10));
}
if ('A' <= c && c <= 'Z') {
value = value.add(BigInteger.valueOf(c - 'A' + 36));
}
}
return value.toString();
}
}