提供哪些输入以查看成功运行的安全SslStream程序

问题描述 投票:1回答:1

我试图在c#中获得安全套接字实现的一些牵引力。在我的追求中,我通过浏览维基百科和其他来源了解了TLS握手的工作原理。

我还想回顾一些示例代码并偶然发现以下https://docs.microsoft.com/en-us/dotnet/api/system.net.security.sslstream?redirectedfrom=MSDN&view=netframework-4.7.2

有两个程序(控制台应用程序)基本上一个用于客户端,另一个用于服务器,以便能够运行程序主方法需要提供一些参数,即MachineName和ServerCertificateName。

请建议如何获取证书以便能够完成证书名称字段。

c# security ssl networking tls1.2
1个回答
1
投票

这是2个线程的简单示例。您可以在2个应用程序之间分隔这些线程

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

© www.soinside.com 2019 - 2024. All rights reserved.