c# - 提供什么输入以查看安全 SslStream 程序的成功运行

标签 c# security ssl networking tls1.2

我正试图在 C# 中的安全套接字实现方面获得一些关注。在我的追求中,我通过维基百科和其他来源了解了 TLS 握手的工作原理。

我还想查看一些示例代码并无意中发现了以下 https://learn.microsoft.com/en-us/dotnet/api/system.net.security.sslstream?redirectedfrom=MSDN&view=netframework-4.7.2

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

请建议如何获得证书以便能够填写证书名称字段。

最佳答案

这是一个有 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

关于c# - 提供什么输入以查看安全 SslStream 程序的成功运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54934919/

相关文章:

apache - 让apache同时重定向到https和tomcat(端口8080)的正确方法是什么

ruby-on-rails - 如何让 Rails、SSL 和 Apache 发挥良好的作用?

c# - MVVM 中的 Window.Closing 事件处理程序

c# - 访问 Request.QueryString[foo] 为 null 但 URL 显示查询字符串/参数就在那里

c# - 将类型名称作为参数用于类型名称集合的方法

java - 限制对 DDD 中对象所有者的访问

ssl - 老板 |无法加载证书 key

c# - 取消或删除计划的作业-HangFire

security - 如果任何其他所有者向所有者授予 GCP 中某些其他帐号的访问权限,我会收到通知吗?

java - 从 MAC KeyChain 访问导出证书并创建 keystore 、信任库