Package org.owasp.esapi.crypto
Class CipherTextSerializer
- java.lang.Object
-
- org.owasp.esapi.crypto.CipherTextSerializer
-
public class CipherTextSerializer extends java.lang.ObjectHelper class to assist with programming language and platform independent serialization ofCipherTextobjects. The serialization is done in network-byte order which is the same as big-endian byte order.This serialization scheme is documented in
Format of Portable Serialization of org.owasp.esapi.crypto.CipherText Objects. Other serialization schemes may be desirable and could be supported (notably, RFC 5083 - Cryptographic Message Syntax (CMS) Authenticated-Enveloped-Data Content Type, or CMS' predecessor, PKCS#7 (RFC 2315)), but these serialization schemes are by comparison very complicated, and do not have extensive support for the various implementation languages which ESAPI supports. (Perhaps wishful thinking that other ESAPI implementations such as ESAPI for .NET, ESAPI for C, ESAPI for C++, etc. will all support a single, common serialization technique so they could exchange encrypted data.)- Since:
- 2.0
- Author:
- kevin.w.wall@gmail.com
-
-
Field Summary
Fields Modifier and Type Field Description static intcipherTextSerializerVersion
-
Constructor Summary
Constructors Constructor Description CipherTextSerializer(byte[] cipherTextSerializedBytes)Given byte array in network byte order (i.e., big-endian order), convert it so that aCipherTextcan be constructed from it.CipherTextSerializer(CipherText cipherTextObj)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description CipherTextasCipherText()Return the actualCipherTextobject.byte[]asSerializedByteArray()Return thisCipherTextobject as a specialized, portable serialized byte array.
-
-
-
Field Detail
-
cipherTextSerializerVersion
public static final int cipherTextSerializerVersion
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
CipherTextSerializer
public CipherTextSerializer(CipherText cipherTextObj)
-
CipherTextSerializer
public CipherTextSerializer(byte[] cipherTextSerializedBytes) throws EncryptionExceptionGiven byte array in network byte order (i.e., big-endian order), convert it so that aCipherTextcan be constructed from it.- Parameters:
cipherTextSerializedBytes- A serializedCipherTextobject with the bytes in network byte order.- Throws:
EncryptionException- Thrown if a validCipherTextobject cannot be reconstructed from the byte array.
-
-
Method Detail
-
asSerializedByteArray
public byte[] asSerializedByteArray()
Return thisCipherTextobject as a specialized, portable serialized byte array.- Returns:
- A serialization of this object. Note that this is not the Java serialization.
-
asCipherText
public CipherText asCipherText()
Return the actualCipherTextobject.- Returns:
- The
CipherTextobject that we are serializing.
-
-