xmlParser
2.44
|
Helper class to include binary data inside XML strings using "Base64 encoding". More...
#include <xmlParser.h>
Public Member Functions | |
XMLParserBase64Tool () | |
~XMLParserBase64Tool () | |
void | freeBuffer () |
Call this function when you have finished using this object to release memory used by the internal buffer. More... | |
XMLSTR | encode (unsigned char *inByteBuf, unsigned int inByteLen, char formatted=0) |
returns a pointer to an internal buffer containing the base64 string containing the binary data encoded from "inByteBuf" More... | |
unsigned char * | decode (XMLCSTR inString, int *outByteLen=NULL, XMLError *xe=NULL) |
returns a pointer to an internal buffer containing the binary data decoded from "inString" More... | |
Static Public Member Functions | |
static int | encodeLength (int inBufLen, char formatted=0) |
return the length of the base64 string that encodes a data buffer of size inBufLen bytes. More... | |
static unsigned int | decodeSize (XMLCSTR inString, XMLError *xe=NULL) |
returns the number of bytes which will be decoded from "inString". More... | |
static unsigned char | decode (XMLCSTR inString, unsigned char *outByteBuf, int inMaxByteOutBuflen, XMLError *xe=NULL) |
deprecated. More... | |
Helper class to include binary data inside XML strings using "Base64 encoding".
The "XMLParserBase64Tool" class allows you to include any binary data (images, sounds,...) into an XML document using "Base64 encoding". This class is completely separated from the rest of the xmlParser library and can be removed without any problem. To include some binary data into an XML file, you must convert the binary data into standard text (using "encode"). To retrieve the original binary data from the b64-encoded text included inside the XML file, use "decode". Alternatively, these functions can also be used to "encrypt/decrypt" some critical data contained inside the XML (it's not a strong encryption at all, but sometimes it can be useful).
Definition at line 689 of file xmlParser.h.
|
inline |
Definition at line 692 of file xmlParser.h.
XMLParserBase64Tool::~XMLParserBase64Tool | ( | ) |
unsigned char* XMLParserBase64Tool::decode | ( | XMLCSTR | inString, |
int * | outByteLen = NULL , |
||
XMLError * | xe = NULL |
||
) |
returns a pointer to an internal buffer containing the binary data decoded from "inString"
The "decode" function returns a pointer to a buffer containing the binary data decoded from "inString" The output buffer will be free'd when the XMLParserBase64Tool object is deleted. All output buffer are sharing the same memory space.
inString | If "instring" is malformed, NULL will be returned |
|
static |
deprecated.
decodes data from "inString" to "outByteBuf". You need to provide the size (in byte) of "outByteBuf" in "inMaxByteOutBuflen". If "outByteBuf" is not large enough or if data is malformed, then "FALSE" will be returned; otherwise "TRUE".
|
static |
returns the number of bytes which will be decoded from "inString".
XMLSTR XMLParserBase64Tool::encode | ( | unsigned char * | inByteBuf, |
unsigned int | inByteLen, | ||
char | formatted = 0 |
||
) |
returns a pointer to an internal buffer containing the base64 string containing the binary data encoded from "inByteBuf"
The "base64Encode" function returns a string containing the base64 encoding of "inByteLen" bytes from "inByteBuf". If "formatted" parameter is true, then there will be a carriage-return every 72 chars. The string will be free'd when the XMLParserBase64Tool object is deleted. All returned strings are sharing the same memory space.
|
static |
return the length of the base64 string that encodes a data buffer of size inBufLen bytes.
formatted | If "formatted"=true, some space will be reserved for a carriage-return every 72 chars. |
void XMLParserBase64Tool::freeBuffer | ( | ) |
Call this function when you have finished using this object to release memory used by the internal buffer.