com.dyuproject.util
Class B64Code

java.lang.Object
  extended by com.dyuproject.util.B64Code

public abstract class B64Code
extends Object

Fast B64 Encoder/Decoder as described in RFC 1421.

Does not insert or interpret whitespace as described in RFC 1521. If you require this you must pre/post process your data.

Note that in a web context the usual case is to not want linebreaks or other white space in the encoded output.

Author:
Brett Sealey (bretts), Greg Wilkins (gregw)

Field Summary
static String __ISO_8859_1
           
 
Constructor Summary
B64Code()
           
 
Method Summary
static byte[] decode(char[] b)
          Fast Base 64 decode as described in RFC 1421.
static String decode(String s)
          Base 64 decode as described in RFC 1421.
static String decode(String s, String charEncoding)
          Base 64 decode as described in RFC 1421.
static char[] encode(byte[] b)
          Fast Base 64 encode as described in RFC 1421.
static String encode(String s)
          Base 64 encode as described in RFC 1421.
static String encode(String s, String charEncoding)
          Base 64 encode as described in RFC 1421.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

__ISO_8859_1

public static final String __ISO_8859_1
Constructor Detail

B64Code

public B64Code()
Method Detail

encode

public static String encode(String s)
Base 64 encode as described in RFC 1421.

Does not insert whitespace as described in RFC 1521.

Parameters:
s - String to encode.
Returns:
String containing the encoded form of the input.

encode

public static String encode(String s,
                            String charEncoding)
                     throws UnsupportedEncodingException
Base 64 encode as described in RFC 1421.

Does not insert whitespace as described in RFC 1521.

Parameters:
s - String to encode.
charEncoding - String representing the name of the character encoding of the provided input String.
Returns:
String containing the encoded form of the input.
Throws:
UnsupportedEncodingException

encode

public static char[] encode(byte[] b)
Fast Base 64 encode as described in RFC 1421.

Does not insert whitespace as described in RFC 1521.

Avoids creating extra copies of the input/output.

Parameters:
b - byte array to encode.
Returns:
char array containing the encoded form of the input.

decode

public static String decode(String s)
Base 64 decode as described in RFC 1421.

Does not attempt to cope with extra whitespace as described in RFC 1521.

Parameters:
s - String to decode
Returns:
String decoded byte array.

decode

public static String decode(String s,
                            String charEncoding)
                     throws UnsupportedEncodingException
Base 64 decode as described in RFC 1421.

Does not attempt to cope with extra whitespace as described in RFC 1521.

Parameters:
s - String to decode
charEncoding - String representing the character encoding used to map the decoded bytes into a String.
Returns:
String decoded byte array.
Throws:
UnsupportedEncodingException

decode

public static byte[] decode(char[] b)
Fast Base 64 decode as described in RFC 1421.

Does not attempt to cope with extra whitespace as described in RFC 1521.

Avoids creating extra copies of the input/output.

Note this code has been flattened for performance.

Parameters:
b - char array to decode.
Returns:
byte array containing the decoded form of the input.
Throws:
IllegalArgumentException - if the input is not a valid B64 encoding.


Copyright © 2013. All Rights Reserved.