All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.tio.utils.mica.HexUtils Maven / Gradle / Ivy

There is a newer version: 1.0.8
Show newest version
/*
 * 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; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy