org.jsmpp.util.HexUtil Maven / Gradle / Ivy
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package org.jsmpp.util;
import java.util.Arrays;
/**
* The Hex utility.
*
* @author uudashr
* @version 1.0
* @since 1.0
*
*/
public class HexUtil {
private static final char[] hexChar = { '0', '1', '2', '3', '4', '5', '6',
'7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
private HexUtil() {
throw new InstantiationError("This class must not be instantiated");
}
/**
* Convert the string to hex string value.
*
* @param data is case sensitive.
* @return the hex string representation of string.
*/
public static String convertStringToHexString(String data) {
return conventBytesToHexString(data.getBytes());
}
/**
* Convert bytes to hex string.
*
* @param data is the bytes.
* @return the hex string representation of bytes.
*/
public static String conventBytesToHexString(byte[] data) {
return convertBytesToHexString(data, 0, data.length);
}
/**
* Convert bytes to hex string value (using Big-Endian rule).
*
* @param data is the bytes.
* @param offset is the offset.
* @param length is the length.
* @return the hex string representation of bytes.
*/
public static String convertBytesToHexString(byte[] data, int offset,
int length) {
return convertBytesToHexString(data, offset, length, "");
}
public static String convertBytesToHexString(byte[] data, int offset, int length, String byteDelimiter) {
final StringBuilder stringBuilder = new StringBuilder((length-offset)*(2+byteDelimiter.length()));
for (int i = offset; i < length; i++) {
stringBuilder.append(hexChar[(data[i] >> 4) & 0x0f]);
stringBuilder.append(hexChar[data[i] & 0x0f]);
stringBuilder.append(byteDelimiter);
}
return stringBuilder.toString();
}
/**
* Convert the hex string to string.
*
* @param hexString is the hex string.
* @return the string value that converted from hex string.
*/
public static String convertHexStringToString(String hexString) {
String uHexString = hexString.toLowerCase();
StringBuilder sBld = new StringBuilder();
for (int i = 0; i < uHexString.length(); i = i + 2) {
char c = (char)Integer.parseInt(uHexString.substring(i, i + 2), 16);
sBld.append(c);
}
return sBld.toString();
}
/**
* Convert the hex string to bytes.
*
* @param hexString is the hex string.
* @return the bytes value that converted from the hex string.
*/
public static byte[] convertHexStringToBytes(String hexString) {
return convertHexStringToBytes(hexString, 0, hexString.length());
}
/**
* Convert the hex string to bytes.
*
* @param hexString is the hex string.
* @param offset is the offset.
* @param endIndex is the end index.
* @return the bytes value that converted from the hex string.
*/
public static byte[] convertHexStringToBytes(String hexString, int offset,
int endIndex) {
byte[] data;
String realHexString = hexString.substring(offset, endIndex)
.toLowerCase();
if ((realHexString.length() % 2) == 0)
data = new byte[realHexString.length() / 2];
else
data = new byte[(int)Math.ceil(realHexString.length() / 2d)];
int j = 0;
char[] tmp;
for (int i = 0; i < realHexString.length(); i += 2) {
try {
tmp = realHexString.substring(i, i + 2).toCharArray();
} catch (StringIndexOutOfBoundsException siob) {
// it only contains one character, so add "0" string
tmp = (realHexString.substring(i) + "0").toCharArray();
}
data[j] = (byte)((Arrays.binarySearch(hexChar, tmp[0]) & 0xf) << 4);
data[j++] |= (byte)(Arrays.binarySearch(hexChar, tmp[1]) & 0xf);
}
for (int i = realHexString.length(); i > 0; i -= 2) {
}
return data;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy