com.gridsystems
Class Base64Decoder

java.lang.Object
  extended by java.io.InputStream
      extended by java.io.FilterInputStream
          extended by com.gridsystems.Base64Decoder
All Implemented Interfaces:
java.io.Closeable

public class Base64Decoder
extends java.io.FilterInputStream

A class to decode Base64 streams and strings. See RFC 1521 section 5.2 for details of the Base64 algorithm.

This class can be used for decoding strings:

 String encoded = "d2VibWFzdGVyOnRyeTJndWVTUw";
 String decoded = Base64Decoder.decode(encoded);
 
or for decoding streams:
 InputStream in = new Base64Decoder(System.in);
 

Version:
1.0, 2000/06/11 Modified by Rodrigo Ruiz for Internal Use in GridSystems
Author:
Jason Hunter, Copyright © 2000

Field Summary
 
Fields inherited from class java.io.FilterInputStream
in
 
Constructor Summary
Base64Decoder(java.io.InputStream in)
          Constructs a new Base64 decoder that reads input from the given InputStream.
 
Method Summary
static byte[] binaryDecode(byte[] encoded)
          Returns the decoded form of the given encoded byte array.
static java.lang.String decode(java.lang.String encoded)
          Returns the decoded form of the given encoded string.
 int read()
          Returns the next decoded character from the stream, or -1 if end of stream was reached.
 int read(byte[] b, int off, int len)
          Reads decoded data into an array of bytes and returns the actual number of bytes read, or -1 if end of stream was reached.
 
Methods inherited from class java.io.FilterInputStream
available, close, mark, markSupported, read, reset, skip
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

Base64Decoder

public Base64Decoder(java.io.InputStream in)
Constructs a new Base64 decoder that reads input from the given InputStream.

Parameters:
in - the input stream
Method Detail

read

public int read()
         throws java.io.IOException
Returns the next decoded character from the stream, or -1 if end of stream was reached.

Overrides:
read in class java.io.FilterInputStream
Returns:
the decoded character, or -1 if the end of the input stream is reached
Throws:
java.io.IOException - if an I/O error occurs

read

public int read(byte[] b,
                int off,
                int len)
         throws java.io.IOException
Reads decoded data into an array of bytes and returns the actual number of bytes read, or -1 if end of stream was reached.

Overrides:
read in class java.io.FilterInputStream
Parameters:
b - the buffer into which the data is read
off - the start offset of the data
len - the maximum number of bytes to read
Returns:
the actual number of bytes read, or -1 if the end of the input stream is reached
Throws:
java.io.IOException - if an I/O error occurs

decode

public static java.lang.String decode(java.lang.String encoded)
Returns the decoded form of the given encoded string.

Parameters:
encoded - the string to decode
Returns:
the decoded form of the encoded string

binaryDecode

public static byte[] binaryDecode(byte[] encoded)
Returns the decoded form of the given encoded byte array.

Parameters:
encoded - the byte array to decode
Returns:
the decoded form of encoded


Copyright © 2007-2008 Grid Systems, S.A.. All Rights Reserved.