Partager via


Code source de Mallory.cs (Exemple CNG)

L'exemple de communication sécurisée CNG (Cryptography Next Generation) est constitué de trois applications console : Alice, Bob et Mallory.L'application Mallory (fichier Mallory.cs) contient le code suivant.


using System;                           // Required for the IDisposable interface
using System.Text;                      // Required for the Encoding class

public partial class CNG_SecureCommunicationExample
{
    static int  MyColor = 5;                        // Bob White displays white text
    static int  OtherColor = 4;                     // Alice Green displays green text
    static bool fDisplaySendMessage = true;         // Boolean flag controls output display visibility

     static void Main()
        {
        InitConsole("Mallory Purple", 310, 490);
        string s = "";
        while (true)
            {
            SplashScreen();
            s = AppControl("receive", "MalloryControlChannel");
            if ("exit" == s) break;              
            Run();
            }
        }          // End Main


    static void Run()
    {
        ASCIIEncoding enc = new ASCIIEncoding();

        InitializeOptions();

        Display("Hi, I'm Mallory, the man in the middle.\n" +
                "I wonder what Alice and Bob are talking about.\n" +
                "I think I'll listen in.\n\n");

        string AliceChannelName = ReceiveChannelName();
        string BobChannelName   = AliceChannelName + "1";
        SendChannelName(BobChannelName);

//-------------------------------------------------------------------------------------------------


        using (Communicator MalloryAlice = new Communicator("client", AliceChannelName))
        using (Communicator MalloryBob = new Communicator("server", BobChannelName))
            {
            string s;
            fDisplaySendMessage = true;

            if (3 <= Version)
                {
                Display("\nI know Alice will publicaly send Bob a digital signature key.\n");
                byte[] DSKey = MalloryAlice.ChMgr.ReadMessage();                      // Read the message
                MalloryAlice.StoreDSKey(DSKey);
                MalloryBob.StoreDSKey(DSKey);

                s = enc.GetString(DSKey);
                if (fVerbose)
                    {
                    Display("Here it is:\n\n");
                    Display(s + "\n\n", 4);
                    }
                MalloryBob.ChMgr.SendMessage(DSKey);
                }

            if (2 <= Version)
                {
                Display(sep, 1);
                Display("Alice and Bob are going to exchange their\n" +
                        "public cryptographic keys through a public channel.\n" +  // Send and Receive ECDH public keys
                        "First, Alice will send Bob her key.\n\n");

                MalloryAlice.Send_or_Receive_PublicCryptoKey("receive", 4);
                Display("Good.  I just intercepted Alice's public key: \n");
                Display("Next, I will send my MalloryAlice public cryptographic key to Alice:\n\nSending...\n");
                MalloryAlice.Send_or_Receive_PublicCryptoKey("send", 5);

                Display("Next, I will send my MalloryBob public cryptographic key to Bob:\n\nSending...\n");
                MalloryBob.Send_or_Receive_PublicCryptoKey("send", 5);
                Display("Now I will receive Bob's public key: \n");
                if (! MalloryBob.Send_or_Receive_PublicCryptoKey("receive", 2))
                    {                
                    Display("I've been discovered!\n\n",0);
                    System.Threading.Thread.Sleep(3000);
                    Console.WriteLine("Press the enter key to continue.");
                    Console.ReadLine();
                    return;
                    }
                Display("Good.  I just intercepted Bob's public key: \n");
                }

//-------------------------------------------------------------------------------------------------
// Now that all the keys have been transmitted, have a conversation.

            if (1 < Version)
                {
                Display(sep, 1);
                Display("Now that they have exchanged their keys,\n" +
                       "they can have a secure conversation:\n\n", 5);
                Display(sep, 1);
                }

            Display("From Alice:\n",7);
            OtherColor = 4; 
            s = MalloryAlice.ReceiveMessage();

            Display("To Bob:\n",7); 
            MalloryBob.SendMessage(s,true);

            Display("From Bob:\n",7); 
            OtherColor = 2; 
            s = MalloryBob.ReceiveMessage();

            Display("To Alice:\n",7); 
            MalloryAlice.SendMessage(s,true);

            Display("From Alice:\n",7); 
            OtherColor = 4; 
            string NewSalesContact = MalloryAlice.ReceiveMessage();

            Display("To Bob:\n",7);
            string FakeMessage = "Coho Winery, OneEleven EveryStreet, Chicago"; 
            MalloryBob.SendMessage(FakeMessage,true);

            Display("From Bob:\n",7);
            OtherColor = 2; 
            MalloryBob.ReceiveMessage();

            Display("To Alice:\n",7); 
            MalloryAlice.SendMessage("I think the address is wrong, but I'll keep trying",true);

           // -------------   Gloat   ------------
            if (!fVerbose && Version >= 3)
                Display(sep1, 1);

            Display("\nI am so clever!\n\n" +
                   "Here is what I received: " + NewSalesContact + "\n" +
                   "and here is what I sent: " + FakeMessage + "\n\n" +
                   "They will never catch me!\n\n\n");

            //-------------------------------------------------------------------------------------------------
            if (Version <= 2)
                Display(sep1, 1);

            Display("Perhaps they will talk some more?\n"      +
                   "I'll listen in on what they say\n" +
                   "and add a few extra characters to their messages\n\n");
            Display(sep + sep1,1);
            s = "";

            while (true)
                {
                Display("From Alice:\n",7);
                OtherColor = 4; 
                s = MalloryAlice.ReceiveMessage();
                if ("" == s)
                    {
                    MalloryBob.SendMessage(s,true);
                    break;
                    }

                Display("Send to Bob:\n",7);
                    if (!MalloryBob.SendMessage(s + " qwerty",true))        // If Alice entered CTRL-C, or SYS_CLOSE
                    break;

                Display("From Bob:\n",7);
                OtherColor = 2; 
                s = MalloryBob.ReceiveMessage();

                Display("Send to Alice:\n",7);
                if ("" != s)
                    s += " ytrewq";

                if (!MalloryAlice.SendMessage(s,true))                  // If Alice entered CTRL-C, or SYS_CLOSE
                    break;

                if ("" == s)
                    break;
                }
            }        // End using (Communicator MalloryAlice, Communicator MalloryBob)
//-------------------------------------------------------------------------------------------------
       }       // End Run

}       // public partial class CNG_SecureCommunicationExample

Voir aussi

Tâches

Comment : créer et exécuter l'exemple CNG

Concepts

Vue d'ensemble du code source (Exemple CNG)

Communication sécurisée Cryptography Next Generation (CNG), exemple

Services de chiffrement