Какие входные данные предоставить для успешного запуска безопасной программы SslStream - PullRequest
0 голосов
/ 01 марта 2019

Я пытаюсь добиться успеха в реализации защищенных сокетов в c #.В своих поисках я почувствовал, как работает TLS-рукопожатие, просматривая Википедию и другие источники.

Я также подумал просмотреть пример кода и наткнулся на следующее https://docs.microsoft.com/en-us/dotnet/api/system.net.security.sslstream?redirectedfrom=MSDN&view=netframework-4.7.2

Существуют две программы (консольные приложения), в основном одна для клиента и другая для сервера, чтобы иметь возможность запускать программу. Для основного метода необходимо указать некоторые аргументы, например, MachineName и ServerCertificateName.

Пожалуйста, предложитекак получить сертификат, чтобы иметь возможность заполнить поле имени сертификата.

1 Ответ

0 голосов
/ 05 марта 2019

Вот простой пример с двумя потоками.Вы можете разделить эти темы между двумя приложениями.

static void Main(string[] args)
{
    var serverThread = new Thread(() =>
    {
        var server = new TcpListener(IPAddress.Any, 12345);
        server.Start();
        var client = server.AcceptTcpClient();
        var ssl = new SslStream(client.GetStream());
        // certificate file with private key and password
        var cert = new X509Certificate2(@"rsa-4096.pfx", "hh87$-Jqo");
        ssl.AuthenticateAsServer(cert);
        ssl.Write(Encoding.ASCII.GetBytes("Hello world"), 0, 11);
        ssl.Flush();
        ssl.Close();
        server.Stop();
    });

    var clientThread = new Thread(() =>
    {
        var client = new TcpClient();
        client.Connect(IPAddress.Loopback, 12345);
        // last parameter disables certificate validation
        var ssl = new SslStream(client.GetStream(), false, (a, b, c, d) => true);
        ssl.AuthenticateAsClient("localhost");
        using (var sr = new StreamReader(ssl, Encoding.ASCII))
        {
            string recivedText = sr.ReadToEnd();
            Console.WriteLine(recivedText);
        }
    });

    serverThread.Start();
    clientThread.Start();

    serverThread.Join();
    clientThread.Join();
}

Вы можете скачать пример сертификата здесь: https://github.com/Zergatul/ZergatulLib/blob/master/ConsoleTest/rsa-4096.pfx

...