Mix networks are routing protocols that create hard-to-trace communications by using a chain of proxy servers known as mixes which take in messages from multiple senders, shuffle them, and send them back out in random order to the next destination (possibly another mix node). This breaks the link between the source of the request and the destination, making it harder for eavesdroppers to trace end-to-end communications. Furthermore, mixes only know the node that it immediately received the message from, and the immediate destination to send the shuffled messages to, making the network resistant to malicious mix nodes.
Each message is encrypted to each proxy using public key cryptography; the resulting encryption is layered like a Russian doll (except that each "doll" is of the same size) with the message as the innermost layer. Each proxy server strips off its own layer of encryption to reveal where to send the message next. If all but one of the proxy servers are compromised by the tracer, untraceability can still be achieved against some weaker adversaries.
The concept of mix networks first described by David Chaum in 1981. Applications that are based on this concept include anonymous remailers (such as Mixmaster) and onion routing (including Tor).
Participant A prepares a message for delivery to participant B by appending a random value R to the message, sealing it with the addressee's public key , appending B’s address, and then sealing the result with the mix's public key . M opens it with his private key, now he knows B’s address, and he sends to B.