security is critical to web services. however, neither xml-rpc nor soap specifications make any explicit security or authentication requirements.
there are three specific security issues with web services −
- confidentiality
- authentication
- network security
confidentiality
if a client sends an xml request to a server, can we ensure that the communication remains confidential?
answer lies here −
- xml-rpc and soap run primarily on top of http.
- http has support for secure sockets layer (ssl).
- communication can be encrypted via ssl.
- ssl is a proven technology and widely deployed.
a single web service may consist of a chain of applications. for example, one large service might tie together the services of three other applications. in this case, ssl is not adequate; the messages need to be encrypted at each node along the service path, and each node represents a potential weak link in the chain. currently, there is no agreed-upon solution to this issue, but one promising solution is the w3c xml encryption standard. this standard provides a framework for encrypting and decrypting entire xml documents or just portions of an xml document. you can check it at www.w3.org/encryption
authentication
if a client connects to a web service, how do we identify the user? is the user authorized to use the service?
the following options can be considered but there is no clear consensus on a strong authentication scheme.
http includes built-in support for basic and digest authentication, and services can therefore be protected in much the same manner as html documents are currently protected.
soap digital signature (soap-dsig) leverages public key cryptography to digitally sign soap messages. it enables the client or server to validate the identity of the other party. check it at www.w3.org/tr/soap-dsig.
the organization for the advancement of structured information standards (oasis) is working on the security assertion markup language (saml).
network security
there is currently no easy answer to this problem, and it has been the subject of much debate. for now, if you are truly intent on filtering out soap or xml-rpc messages, one possibility is to filter out all http post requests that set their content type to text/xml.
another alternative is to filter the soapaction http header attribute. firewall vendors are also currently developing tools explicitly designed to filter web service traffic.