public class

Hex

extends Object
implements BinaryDecoder BinaryEncoder
java.lang.Object
   ↳ org.apache.commons.codec.binary.Hex

Class Overview

Hex encoder and decoder. The charset used for certain operation can be set, the default is set in DEFAULT_CHARSET_NAME

Summary

Constants
String DEFAULT_CHARSET_NAME Default charset name is UTF_8
Public Constructors
Hex()
Creates a new codec with the default charset name DEFAULT_CHARSET_NAME
Hex(String csName)
Creates a new codec with the given charset name.
Public Methods
byte[] decode(byte[] array)
Converts an array of character bytes representing hexadecimal values into an array of bytes of those same values.
Object decode(Object object)
Converts a String or an array of character bytes representing hexadecimal values into an array of bytes of those same values.
static byte[] decodeHex(char[] data)
Converts an array of characters representing hexadecimal values into an array of bytes of those same values.
byte[] encode(byte[] array)
Converts an array of bytes into an array of bytes for the characters representing the hexadecimal values of each byte in order.
Object encode(Object object)
Converts a String or an array of bytes into an array of characters representing the hexadecimal values of each byte in order.
static char[] encodeHex(byte[] data, boolean toLowerCase)
Converts an array of bytes into an array of characters representing the hexadecimal values of each byte in order.
static char[] encodeHex(byte[] data)
Converts an array of bytes into an array of characters representing the hexadecimal values of each byte in order.
static String encodeHexString(byte[] data)
Converts an array of bytes into a String representing the hexadecimal values of each byte in order.
String getCharsetName()
Gets the charset name.
String toString()
Returns a string representation of the object, which includes the charset name.
Protected Methods
static char[] encodeHex(byte[] data, char[] toDigits)
Converts an array of bytes into an array of characters representing the hexadecimal values of each byte in order.
static int toDigit(char ch, int index)
Converts a hexadecimal character to an integer.
[Expand]
Inherited Methods
From class java.lang.Object
From interface org.apache.commons.codec.BinaryDecoder
From interface org.apache.commons.codec.BinaryEncoder
From interface org.apache.commons.codec.Decoder
From interface org.apache.commons.codec.Encoder

Constants

public static final String DEFAULT_CHARSET_NAME

Default charset name is UTF_8

Constant Value: "UTF-8"

Public Constructors

public Hex ()

Creates a new codec with the default charset name DEFAULT_CHARSET_NAME

public Hex (String csName)

Creates a new codec with the given charset name.

Parameters
csName the charset name.

Public Methods

public byte[] decode (byte[] array)

Converts an array of character bytes representing hexadecimal values into an array of bytes of those same values. The returned array will be half the length of the passed array, as it takes two characters to represent any given byte. An exception is thrown if the passed char array has an odd number of elements.

Parameters
array An array of character bytes containing hexadecimal digits
Returns
  • A byte array containing binary data decoded from the supplied byte array (representing characters).
Throws
DecoderException Thrown if an odd number of characters is supplied to this function

public Object decode (Object object)

Converts a String or an array of character bytes representing hexadecimal values into an array of bytes of those same values. The returned array will be half the length of the passed String or array, as it takes two characters to represent any given byte. An exception is thrown if the passed char array has an odd number of elements.

Parameters
object A String or, an array of character bytes containing hexadecimal digits
Returns
  • A byte array containing binary data decoded from the supplied byte array (representing characters).
Throws
DecoderException Thrown if an odd number of characters is supplied to this function or the object is not a String or char[]

public static byte[] decodeHex (char[] data)

Converts an array of characters representing hexadecimal values into an array of bytes of those same values. The returned array will be half the length of the passed array, as it takes two characters to represent any given byte. An exception is thrown if the passed char array has an odd number of elements.

Parameters
data An array of characters containing hexadecimal digits
Returns
  • A byte array containing binary data decoded from the supplied char array.
Throws
DecoderException Thrown if an odd number or illegal of characters is supplied

public byte[] encode (byte[] array)

Converts an array of bytes into an array of bytes for the characters representing the hexadecimal values of each byte in order. The returned array will be double the length of the passed array, as it takes two characters to represent any given byte.

The conversion from hexadecimal characters to the returned bytes is performed with the charset named by getCharsetName().

Parameters
array a byte[] to convert to Hex characters
Returns
  • A byte[] containing the bytes of the hexadecimal characters
Throws
IllegalStateException if the charsetName is invalid. This API throws IllegalStateException instead of UnsupportedEncodingException for backward compatibility.

public Object encode (Object object)

Converts a String or an array of bytes into an array of characters representing the hexadecimal values of each byte in order. The returned array will be double the length of the passed String or array, as it takes two characters to represent any given byte.

The conversion from hexadecimal characters to bytes to be encoded to performed with the charset named by getCharsetName().

Parameters
object a String, or byte[] to convert to Hex characters
Returns
  • A char[] containing hexadecimal characters
Throws
EncoderException Thrown if the given object is not a String or byte[]

public static char[] encodeHex (byte[] data, boolean toLowerCase)

Converts an array of bytes into an array of characters representing the hexadecimal values of each byte in order. The returned array will be double the length of the passed array, as it takes two characters to represent any given byte.

Parameters
data a byte[] to convert to Hex characters
toLowerCase true converts to lowercase, false to uppercase
Returns
  • A char[] containing hexadecimal characters

public static char[] encodeHex (byte[] data)

Converts an array of bytes into an array of characters representing the hexadecimal values of each byte in order. The returned array will be double the length of the passed array, as it takes two characters to represent any given byte.

Parameters
data a byte[] to convert to Hex characters
Returns
  • A char[] containing hexadecimal characters

public static String encodeHexString (byte[] data)

Converts an array of bytes into a String representing the hexadecimal values of each byte in order. The returned String will be double the length of the passed array, as it takes two characters to represent any given byte.

Parameters
data a byte[] to convert to Hex characters
Returns
  • A String containing hexadecimal characters

public String getCharsetName ()

Gets the charset name.

Returns
  • the charset name.

public String toString ()

Returns a string representation of the object, which includes the charset name.

Returns
  • a string representation of the object.

Protected Methods

protected static char[] encodeHex (byte[] data, char[] toDigits)

Converts an array of bytes into an array of characters representing the hexadecimal values of each byte in order. The returned array will be double the length of the passed array, as it takes two characters to represent any given byte.

Parameters
data a byte[] to convert to Hex characters
toDigits the output alphabet
Returns
  • A char[] containing hexadecimal characters

protected static int toDigit (char ch, int index)

Converts a hexadecimal character to an integer.

Parameters
ch A character to convert to an integer digit
index The index of the character in the source
Returns
  • An integer
Throws
DecoderException Thrown if ch is an illegal hex character