Message Encryption/Decryption Mechanism
- Web service invocation
- Retrieve client's X.509 certificate and private key
- Digitally sign message (e.g SOAP body) using private key
- Include client application's X.509 certificate in SOAP header as binary security token.
- Encrypt message with symmetrical algorithm using a shared key.
- Retrieve public key of the service provider's X.509 certificate
- Encrypt shared key with asymmetric algorithm using service provider's public key.
- Include encrypted shared key in SOAP header
- Include reference to Service Provider's certificate in SOAP header.
- SP SOAP runtime recieves request
- Identify Service Provider's X.509 certification from reference in SOAP header
- Retrieve Service Provider's X.509 certificate and keys
- Decrypt shared key with asymmetric algorithms using private key of certificate
- Decrypt message with sysmmetric algorithm using shared key
- Retrieve sender's X.509 public key from binary security token in SOAP header
- Validate digital signature of message that also authenticate sender
- Call web service implmentation
- Process request
Great post. You have nicely explained the complete mechanism of message encryption/decryption in this article. Both the images posted clearly depicts the flow how message is encrypted at the client side and then how the server process the request message.
ReplyDeletedigital signatures