Package org.apache.commons.codec.net
Class BCodec
java.lang.Object
org.apache.commons.codec.net.BCodec
- All Implemented Interfaces:
Decoder,Encoder,StringDecoder,StringEncoder
public class BCodec extends Object implements StringEncoder, StringDecoder
Identical to the Base64 encoding defined by RFC 1521 and allows a character set to be specified.
RFC 1522 describes techniques to allow the encoding of non-ASCII text in various portions of a RFC 822 [2] message header, in a manner which is unlikely to confuse existing message handling software.
- Since:
- 1.3
- Version:
- $Id: BCodec.java,v 1.5 2004/04/13 22:46:37 ggregory Exp $
- Author:
- Apache Software Foundation
- See Also:
- MIME (Multipurpose Internet Mail Extensions) Part Two: Message Header Extensions for Non-ASCII Text
-
Constructor Summary
-
Method Summary
Modifier and Type Method Description Objectdecode(Object value)Decodes a Base64 object into its original form.Stringdecode(String value)Decodes a Base64 string into its original form.protected StringdecodeText(String text)Applies an RFC 1522 compliant decoding scheme to the given string of text.protected byte[]doDecoding(byte[] bytes)Decodes an array of bytes using the defined encoding schemeprotected byte[]doEncoding(byte[] bytes)Encodes an array of bytes using the defined encoding schemeObjectencode(Object value)Encodes an object into its Base64 form using the default charset.Stringencode(String value)Encodes a string into its Base64 form using the default charset.Stringencode(String value, String charset)Encodes a string into its Base64 form using the specified charset.protected StringencodeText(String text, String charset)Applies an RFC 1522 compliant encoding scheme to the given string of text with the given charset.StringgetDefaultCharset()The default charset used for string decoding and encoding.protected StringgetEncoding()Returns the codec name (referred to as encoding in the RFC 1522)
-
Constructor Details
-
BCodec
public BCodec()Default constructor. -
BCodec
Constructor which allows for the selection of a default charset- Parameters:
charset- the default string charset to use.- See Also:
- JRE character encoding names
-
-
Method Details
-
getEncoding
Returns the codec name (referred to as encoding in the RFC 1522)- Returns:
- name of the codec
-
doEncoding
Encodes an array of bytes using the defined encoding scheme- Parameters:
bytes- Data to be encoded- Returns:
- A byte array containing the encoded data
- Throws:
EncoderException- thrown if the Encoder encounters a failure condition during the encoding process.
-
doDecoding
Decodes an array of bytes using the defined encoding scheme- Parameters:
bytes- Data to be decoded- Returns:
- a byte array that contains decoded data
- Throws:
DecoderException- A decoder exception is thrown if a Decoder encounters a failure condition during the decode process.
-
encode
Encodes a string into its Base64 form using the specified charset. Unsafe characters are escaped.- Parameters:
value- string to convert to Base64 formcharset- the charset for pString- Returns:
- Base64 string
- Throws:
EncoderException- thrown if a failure condition is encountered during the encoding process.
-
encode
Encodes a string into its Base64 form using the default charset. Unsafe characters are escaped.- Specified by:
encodein interfaceStringEncoder- Parameters:
value- string to convert to Base64 form- Returns:
- Base64 string
- Throws:
EncoderException- thrown if a failure condition is encountered during the encoding process.
-
decode
Decodes a Base64 string into its original form. Escaped characters are converted back to their original representation.- Specified by:
decodein interfaceStringDecoder- Parameters:
value- Base64 string to convert into its original form- Returns:
- original string
- Throws:
DecoderException- A decoder exception is thrown if a failure condition is encountered during the decode process.
-
encode
Encodes an object into its Base64 form using the default charset. Unsafe characters are escaped.- Specified by:
encodein interfaceEncoder- Parameters:
value- object to convert to Base64 form- Returns:
- Base64 object
- Throws:
EncoderException- thrown if a failure condition is encountered during the encoding process.
-
decode
Decodes a Base64 object into its original form. Escaped characters are converted back to their original representation.- Specified by:
decodein interfaceDecoder- Parameters:
value- Base64 object to convert into its original form- Returns:
- original object
- Throws:
DecoderException- A decoder exception is thrown if a failure condition is encountered during the decode process.
-
getDefaultCharset
The default charset used for string decoding and encoding.- Returns:
- the default string charset.
-
encodeText
protected String encodeText(String text, String charset) throws EncoderException, UnsupportedEncodingExceptionApplies an RFC 1522 compliant encoding scheme to the given string of text with the given charset. This method constructs the "encoded-word" header common to all the RFC 1522 codecs and then invokesdoEncoding(byte [])method of a concrete class to perform the specific enconding.- Parameters:
text- a string to encodecharset- a charset to be used- Returns:
- RFC 1522 compliant "encoded-word"
- Throws:
EncoderException- thrown if there is an error conidition during the Encoding process.UnsupportedEncodingException- thrown if charset is not supported- See Also:
- JRE character encoding names
-
decodeText
Applies an RFC 1522 compliant decoding scheme to the given string of text. This method processes the "encoded-word" header common to all the RFC 1522 codecs and then invokesdoEncoding(byte [])method of a concrete class to perform the specific deconding.- Parameters:
text- a string to decode- Throws:
DecoderException- thrown if there is an error conidition during the Decoding process.UnsupportedEncodingException- thrown if charset specified in the "encoded-word" header is not supported
-