|  | Home | Documentation | The smdevp signed message digest engine updated Mon May 13 2024 by Robert van Engelen | 
The gSOAP smdevp engine computes signed/unsigned message digests over any type of data using the EVP interface of OpenSSL. It currently supports MD5, SHA1/224/256/384/512, HMAC_SHA1/224/256/384/512, DSA_SHA1/224256/384/512, and RSA_SHA1/224/256/384/512.
A digest or signature algorithm is selected with one the following:
Algorithm options:
The smdevp engine wraps the EVP API with three new functions:
A higher-level interface for computing (signed) message digests over messages produced by the gSOAP engine is defined by two new functions:
Compile all source codes with -DWITH_OPENSSL and link with ssl and crypto libraries.
Here is an example to sign an XML serialized C++ object using an RSA private key applied to the SHA digest of the serialized object:
Compile the gSOAP sources and your code with -DWITH_OPENSSL and link with OpenSSL libraries.
There is no XML output generated by this example, as the object is simply serialized to the smdevp engine. To actually pass the XML object through the smdevp engine and output it to a stream or file simultaneously, use the SOAP_SMD_PASSTHRU flag with the algorithm selection as follows:
Note that we used soap_begin_send and soap_end_send to emit the XML to a stream. Each type also has a reader (e.g. soap_read_ns__Object) and writer (e.g. soap_write_ns__Object) that can be used instead as these include soap_begin_recv/soap_end_recv and soap_begin_send/soap_end_send call sequences.
To verify the signature of an object read from a stream or file, we pass it through the smdevp engine as follows:
To verify the signature of an object stored in memory, we use the RSA public key and re-run the octet stream (by re-serialization in this example) through the smdevp engine using the SOAP_SMD_VRFY_RSA_SHA1 algorithm. Note that a PEM file may contain both the (encrypted) private and public keys.
The HMAC algorithm uses a shared secret key (hence both the sender and receiver must keep it secret) to sign and verify a message:
HMAC signature verification proceeds by recomputing the signature value for comparison.
A digest is a hash value of an octet stream computed using the MD5 or SHA algorithms:
Note that indentation (SOAP_XML_INDENT) and exc-c14n canonicalization (SOAP_XML_CANONICAL) affects the XML serialization format and, therefore, the digest or signature produced.