org.tio.utils.mica.HexUtils Maven / Gradle / Ivy
Show all versions of mica-net-utils Show documentation
/*
* Copyright (c) 2019-2029, Dreamlu 卢春梦 ([email protected] & www.dreamlu.net).
*
* Licensed under the GNU LESSER GENERAL PUBLIC LICENSE 3.0;
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.gnu.org/licenses/lgpl.html
*
* 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.tio.utils.mica;
import org.tio.utils.hutool.StrUtil;
import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets;
/**
* hex 工具,编解码全用 byte
*
* @author L.cm
*/
public class HexUtils {
public static final Charset DEFAULT_CHARSET = StandardCharsets.UTF_8;
private static final byte[] DIGITS_LOWER = new byte[]{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};
private static final byte[] DIGITS_UPPER = new byte[]{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'};
private static final int OFFSET_BASIS = (int) 2166136261L;
private static final int PRIME = 16777619;
/**
* FNV1算法
*
* @param src src
* @return int
*/
public static int hashFNV1(byte[] src) {
return hashFNV1(src, 0, src.length);
}
/**
* FNV1算法
*
* @param src src
* @param start start
* @param len len
* @return int
*/
public static int hashFNV1(byte[] src, int start, int len) {
int hash = OFFSET_BASIS;
int end = start + len;
for (int i = start; i < end; i++) {
hash = (hash ^ src[i]) * PRIME;
}
return hash;
}
/**
* encode Hex
*
* @param data data to hex
* @return hex bytes
*/
public static byte[] encode(byte[] data) {
return encode(data, true);
}
/**
* encode Hex
*
* @param data data to hex
* @param toLowerCase 是否小写
* @return hex bytes
*/
public static byte[] encode(byte[] data, boolean toLowerCase) {
return encode(data, toLowerCase ? DIGITS_LOWER : DIGITS_UPPER);
}
/**
* encode Hex
*
* @param data byte to Hex
* @return bytes as a hex string
*/
public static String encode(byte data) {
byte[] out = new byte[2];
out[0] = DIGITS_LOWER[(0xF0 & data) >>> 4];
out[1] = DIGITS_LOWER[0xF & data];
return new String(out);
}
/**
* encode Hex
*
* @param data Data to Hex
* @return bytes as a hex string
*/
private static byte[] encode(byte[] data, byte[] digits) {
int len = data.length;
byte[] out = new byte[len << 1];
for (int i = 0, j = 0; i < len; i++) {
out[j++] = digits[(0xF0 & data[i]) >>> 4];
out[j++] = digits[0xF & data[i]];
}
return out;
}
/**
* encode Hex
*
* @param data Data to Hex
* @param toLowerCase 是否小写
* @return bytes as a hex string
*/
public static String encodeToString(byte[] data, boolean toLowerCase) {
return new String(encode(data, toLowerCase), DEFAULT_CHARSET);
}
/**
* encode Hex
*
* @param data Data to Hex
* @return bytes as a hex string
*/
public static String encodeToString(byte[] data) {
return encodeToString(data, DEFAULT_CHARSET);
}
/**
* encode Hex
*
* @param data Data to Hex
* @param charset Charset
* @return bytes as a hex string
*/
public static String encodeToString(byte[] data, Charset charset) {
return new String(encode(data), charset);
}
/**
* encode Hex
*
* @param data Data to Hex
* @return bytes as a hex string
*/
public static String encodeToString(String data) {
if (StrUtil.isBlank(data)) {
return null;
}
return encodeToString(data.getBytes(DEFAULT_CHARSET));
}
/**
* encode Hex
*
* @param data Data to Hex
* @param charset Charset
* @return bytes as a hex string
*/
public static String encodeToString(String data, Charset charset) {
return encodeToString(data, charset, charset);
}
/**
* encode Hex
*
* @param data Data to Hex
* @param dataCharset Charset
* @param toCharset Charset
* @return bytes as a hex string
*/
public static String encodeToString(String data, Charset dataCharset, Charset toCharset) {
if (StrUtil.isBlank(data)) {
return null;
}
return encodeToString(data.getBytes(dataCharset), toCharset);
}
/**
* decode Hex
*
* @param data Hex data
* @return decode hex to bytes
*/
public static byte[] decode(String data) {
return decode(data, DEFAULT_CHARSET);
}
/**
* decode Hex
*
* @param data Hex data
* @param charset Charset
* @return decode hex to bytes
*/
public static byte[] decode(String data, Charset charset) {
if (StrUtil.isBlank(data)) {
return null;
}
return decode(data.getBytes(charset));
}
/**
* decodeToString Hex
*
* @param data Data to Hex
* @return bytes as a hex string
*/
public static String decodeToString(byte[] data) {
return decodeToString(data, DEFAULT_CHARSET);
}
/**
* decodeToString Hex
*
* @param data Data to Hex
* @param charset Charset
* @return bytes as a hex string
*/
public static String decodeToString(byte[] data, Charset charset) {
byte[] decodeBytes = decode(data);
return new String(decodeBytes, charset);
}
/**
* decodeToString Hex
*
* @param data Data to Hex
* @return bytes as a hex string
*/
public static String decodeToString(String data) {
if (StrUtil.isBlank(data)) {
return null;
}
return decodeToString(data.getBytes(DEFAULT_CHARSET));
}
/**
* decodeToString Hex
*
* @param data Data to Hex
* @param charset Charset
* @return bytes as a hex string
*/
public static String decodeToString(String data, Charset charset) {
return decodeToString(data, charset, charset);
}
/**
* decodeToString Hex
*
* @param data Data to Hex
* @param dataCharset Charset
* @param toCharset Charset
* @return bytes as a hex string
*/
public static String decodeToString(String data, Charset dataCharset, Charset toCharset) {
if (StrUtil.isBlank(data)) {
return null;
}
return decodeToString(data.getBytes(dataCharset), toCharset);
}
/**
* decode Hex
*
* @param data Hex data
* @return decode hex to bytes
*/
public static byte[] decode(byte[] data) {
int len = data.length;
if ((len & 0x01) != 0) {
throw new IllegalArgumentException("hexBinary needs to be even-length: " + len);
}
byte[] out = new byte[len >> 1];
for (int i = 0, j = 0; j < len; i++) {
int f = toDigit(data[j], j) << 4;
j++;
f |= toDigit(data[j], j);
j++;
out[i] = (byte) (f & 0xFF);
}
return out;
}
private static int toDigit(byte b, int index) {
int digit = Character.digit(b, 16);
if (digit == -1) {
throw new IllegalArgumentException("Illegal hexadecimal byte " + b + " at index " + index);
}
return digit;
}
}