NumEncodeUtil.java 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. package com.yqh.p2p.utils.codec;
  2. /**
  3. * 62进制数字
  4. */
  5. public class NumEncodeUtil {
  6. /**
  7. * 62个字母和数字,含大小写
  8. */
  9. public static final char[] N62_CHARS = { '0', '1', '2', '3', '4', '5', '6',
  10. '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',
  11. 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W',
  12. 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j',
  13. 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w',
  14. 'x', 'y', 'z' };
  15. /**
  16. * 36个小写字母和数字
  17. */
  18. public static final char[] N36_CHARS = { '0', '1', '2', '3', '4', '5', '6',
  19. '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j',
  20. 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w',
  21. 'x', 'y', 'z' };
  22. /**
  23. * 长整型用N36表示的最大长度
  24. */
  25. public static final int LONG_N36_LEN = 13;
  26. /**
  27. * 长整型用N62表示的最大长度
  28. */
  29. public static final int LONG_N62_LEN = 11;
  30. /**
  31. * 长整型转换成字符串
  32. *
  33. * @param l
  34. * @param chars
  35. * @return
  36. */
  37. private static StringBuilder longToNBuf(long l, char[] chars) {
  38. int upgrade = chars.length;
  39. StringBuilder result = new StringBuilder();
  40. int last;
  41. while (l > 0) {
  42. last = (int) (l % upgrade);
  43. result.append(chars[last]);
  44. l /= upgrade;
  45. }
  46. return result;
  47. }
  48. /**
  49. * 长整数转换成N62
  50. *
  51. * @param l
  52. * @return
  53. */
  54. public static String longToN62(long l) {
  55. return longToNBuf(l, N62_CHARS).reverse().toString();
  56. }
  57. /**
  58. * 长整型转换成N36
  59. *
  60. * @param l
  61. * @return
  62. */
  63. public static String longToN36(long l) {
  64. return longToNBuf(l, N36_CHARS).reverse().toString();
  65. }
  66. /**
  67. * 长整数转换成N62
  68. *
  69. * @param l
  70. * @param length
  71. * 如不足length长度,则补足0。
  72. * @return
  73. */
  74. public static String longToN62(long l, int length) {
  75. StringBuilder sb = longToNBuf(l, N62_CHARS);
  76. for (int i = sb.length(); i < length; i++) {
  77. sb.append('0');
  78. }
  79. return sb.reverse().toString();
  80. }
  81. /**
  82. * 长整型转换成N36
  83. *
  84. * @param l
  85. * @param length
  86. * 如不足length长度,则补足0。
  87. * @return
  88. */
  89. public static String longToN36(long l, int length) {
  90. StringBuilder sb = longToNBuf(l, N36_CHARS);
  91. for (int i = sb.length(); i < length; i++) {
  92. sb.append('0');
  93. }
  94. return sb.reverse().toString();
  95. }
  96. /**
  97. * N62转换成整数
  98. *
  99. * @param n62
  100. * @return
  101. */
  102. public static long n62ToLong(String n62) {
  103. return nToLong(n62, N62_CHARS);
  104. }
  105. /**
  106. * N36转换成整数
  107. *
  108. * @param n36
  109. * @return
  110. */
  111. public static long n36ToLong(String n36) {
  112. return nToLong(n36, N36_CHARS);
  113. }
  114. private static long nToLong(String s, char[] chars) {
  115. char[] nc = s.toCharArray();
  116. long result = 0;
  117. long pow = 1;
  118. for (int i = nc.length - 1; i >= 0; i--, pow *= chars.length) {
  119. int n = findNIndex(nc[i], chars);
  120. result += n * pow;
  121. }
  122. return result;
  123. }
  124. private static int findNIndex(char c, char[] chars) {
  125. for (int i = 0; i < chars.length; i++) {
  126. if (c == chars[i]) {
  127. return i;
  128. }
  129. }
  130. throw new RuntimeException("N62(N36)非法字符:" + c);
  131. }
  132. public static void main(String[] args) {
  133. String str = longToN62(13720176797l);
  134. System.out.println(str);
  135. System.out.println(n62ToLong(str));
  136. }
  137. }