我试图在c#中获得安全套接字实现的一些牵引力。在我的追求中,我通过浏览维基百科和其他来源了解了TLS握手的工作原理。
我还想回顾一些示例代码并偶然发现以下https://docs.microsoft.com/en-us/dotnet/api/system.net.security.sslstream?redirectedfrom=MSDN&view=netframework-4.7.2
有两个程序(控制台应用程序)基本上一个用于客户端,另一个用于服务器,以便能够运行程序主方法需要提供一些参数,即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