59 lines
1.6 KiB
Java
59 lines
1.6 KiB
Java
|
class utilTest {
|
||
|
|
||
|
public static void main(String[] argv) throws Throwable {
|
||
|
byte[] b = new byte[] {
|
||
|
0x01, 0x23, 0x45, 0x67, (byte) 0x89, (byte) 0xab,
|
||
|
(byte) 0xcd, (byte) 0xef
|
||
|
};
|
||
|
String s = "0123456789ABCDEF";
|
||
|
System.out.println(toString(b));
|
||
|
System.out.println(s);
|
||
|
System.out.println(toString(toBytesFromString(s)));
|
||
|
}
|
||
|
|
||
|
// The following comes from the GNU Crypto project gnu.crypto.util.Util
|
||
|
|
||
|
private static final char[] HEX_DIGITS = {
|
||
|
'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'
|
||
|
};
|
||
|
|
||
|
public static byte[] toBytesFromString(String s) {
|
||
|
int limit = s.length();
|
||
|
byte[] result = new byte[((limit + 1) / 2)];
|
||
|
int i = 0, j = 0;
|
||
|
if ((limit % 2) == 1) {
|
||
|
result[j++] = (byte) fromDigit(s.charAt(i++));
|
||
|
}
|
||
|
while (i < limit) {
|
||
|
result[j++] =
|
||
|
(byte)((fromDigit(s.charAt(i++)) << 4) | fromDigit(s.charAt(i++)));
|
||
|
}
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
public static int fromDigit(char c) {
|
||
|
if (c >= '0' && c <= '9') {
|
||
|
return c - '0';
|
||
|
} else if (c >= 'A' && c <= 'F') {
|
||
|
return c - 'A' + 10;
|
||
|
} else if (c >= 'a' && c <= 'f') {
|
||
|
return c - 'a' + 10;
|
||
|
} else
|
||
|
throw new IllegalArgumentException("Invalid hexadecimal digit: " + c);
|
||
|
}
|
||
|
|
||
|
public static String toString(byte[] ba) {
|
||
|
return toString(ba, 0, ba.length);
|
||
|
}
|
||
|
|
||
|
public static final String toString(byte[] ba, int offset, int length) {
|
||
|
char[] buf = new char[length * 2];
|
||
|
for (int i = 0, j = 0, k; i < length; ) {
|
||
|
k = ba[offset + i++];
|
||
|
buf[j++] = HEX_DIGITS[(k >>> 4) & 0x0F];
|
||
|
buf[j++] = HEX_DIGITS[ k & 0x0F];
|
||
|
}
|
||
|
return new String(buf);
|
||
|
}
|
||
|
}
|