Page 1 of 1
Does anyone know how to use purebasic as a socket server with TLS and the native Csharp client?
Posted: Sat Jan 11, 2025 4:40 am
by skinkairewalker
Hello everyone, how are you?
Does anyone know how to use csharp as a client socket that has TLS support with the server made in purebasic?
Re: Does anyone know how to use purebasic as a socket server with TLS and the native Csharp client?
Posted: Sun Jan 12, 2025 10:26 pm
by skinkairewalker
solved :
Csharp Client[ ignoring self-signed/untrusted certificates ]
Code: Select all
using System;
using System.IO;
using System.Net.Security;
using System.Net.Sockets;
using System.Security.Cryptography.X509Certificates;
using System.Text;
using System.Threading.Tasks;
class TlsClientWithCertificate
{
public static async Task Main(string[] args)
{
string server = "localhost";
int port = 20252;
try
{
using (TcpClient client = new TcpClient(server, port))
{
Console.WriteLine("TCP connected.");
using (SslStream sslStream = new SslStream(
client.GetStream(),
false,
new RemoteCertificateValidationCallback(ValidateServerCertificate)
))
{
await sslStream.AuthenticateAsClientAsync(new SslClientAuthenticationOptions
{
TargetHost = server,
EnabledSslProtocols = System.Security.Authentication.SslProtocols.Tls13
});
Console.WriteLine("Connection TLS works.");
Console.WriteLine($"Protocol name: {sslStream.SslProtocol}");
string message = "Hello, Server!";
byte[] buffer = Encoding.UTF8.GetBytes(message);
await sslStream.WriteAsync(buffer, 0, buffer.Length);
Console.WriteLine("Message Sent.");
}
}
}
catch (Exception ex)
{
Console.WriteLine($"Error: {ex.Message}");
}
}
private static bool ValidateServerCertificate(
object sender,
X509Certificate certificate,
X509Chain chain,
SslPolicyErrors sslPolicyErrors)
{
if (sslPolicyErrors == SslPolicyErrors.None)
return true;
Console.WriteLine($"Cert Error: {sslPolicyErrors}");
return true;
}
}
Purebasic Server:
Code: Select all
EnableExplicit
Define.i Con, Timeout, Length
Define Receive$, Key$, Cert$, ClientID
Define *Buffer
Key$ = "-----BEGIN PRIVATE KEY-----"+#LF$+
"MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBAPEbSQq/uwESZduPtDd83qXXkSPf6lUNa17xhM2fOZQxGr0Fdmvw6IsC+QGX25EE1TG6TFQkHlM2rW8y6a3WEC/WzCNWaTCPYD/rguiAFG+4eQmwHjiJFVec0InjjSG9SX8xwS/gQeWdQniKROO4DmMJO8N7mdUhdHODSntXdr9zAgMBAAECgYAE+VMgbaQl+YMwbF6DZogRU8kivFPRPV2hr8nVlBtT+09Z5uryfx3NAFqytbdJ3penVviMI9KcVNxvFtXLSEc9KyjzgysorAfUpwFuECCLDbOXX0HlV6rgkqJdhyV6FybcDLvgcvulHQ64QdYRhW+jPx7vXk3h0/JRFqKQJsY7QQJBAPrDLJRPbAw+Mlq1fHBWk8Z1Qn1ivPAmz+2nPAgDya/xdAlb9GbFAMzCS3upIBpxW70uLI04OuTVhwYL194I5C0CQQD2JHtHp25SkIDpBgZGicEC7yAIE/wPC0P9X85UJqXx5dPx4HbEc8lqSKMbCzkbHyvjHonSHu00QxU1W6ZALFYfAkBcPWzphSl+e2Z0XWvPutkS2FFD5A0R3YUAq1J2tEX9NTj0tGF7aB36M8ImU7jeYTJYrWJv8+4d/Ll1LOgT4XtlAkAxofOV5EYTsf28fzF+wcJAtDUyS81Uv0HLcqkpQM3PdDeDm253eJ2Rp+nzxxSRynxQBNVnoELWefxp0Pw6DnajAkBF5h7fQIbwAEPrhDzhjMXU7g9k9KzkkJN/bluLbleqkkAz1kfkGtWXJdGITZuY4K/X2yp1diWQ0utZjmOmhWsl"+#LF$+
"-----END PRIVATE KEY-----"
Cert$ = "-----BEGIN CERTIFICATE-----"+#LF$+
"MIICnTCCAgYCCQD0AWy2vzfcpzANBgkqhkiG9w0BAQUFADCBkjELMAkGA1UEBhMCVVMxDjAMBgNVBAgTBVN0YXRlMQ0wCwYDVQQHEwRDaXR5MRUwEwYDVQQKEwxPcmdhbml6YXRpb24xHDAaBgNVBAsTE09yZ2FuaXphdGlvbmFsIFVuaXQxLzAtBgNVBAMTJkNvbW1vbiBOYW1lIChlLmcuLCB5b3VyIHNlcnZlciBkb21haW4pMB4XDTI0MTEwNjE2NTI1N1oXDTI0MTIwNjE2NTI1N1owgZIxCzAJBgNVBAYTAlVTMQ4wDAYDVQQIEwVTdGF0ZTENMAsGA1UEBxMEQ2l0eTEVMBMGA1UEChMMT3JnYW5pemF0aW9uMRwwGgYDVQQLExNPcmdhbml6YXRpb25hbCBVbml0MS8wLQYDVQQDEyZDb21tb24gTmFtZSAoZS5nLiwgeW91ciBzZXJ2ZXIgZG9tYWluKTCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEA8RtJCr+7ARJl24+0N3zepdeRI9/qVQ1rXvGEzZ85lDEavQV2a/DoiwL5AZfbkQTVMbpMVCQeUzatbzLprdYQL9bMI1ZpMI9gP+uC6IAUb7h5CbAeOIkVV5zQieONIb1JfzHBL+BB5Z1CeIpE47gOYwk7w3uZ1SF0c4NKe1d2v3MCAwEAATANBgkqhkiG9w0BAQUFAAOBgQCprm5a5bg1LqCDdtwDTnRDmVcca6HoUlvbjZLmWdLjltG1McNAATppTy/bF7vT3jXLobA1Vzs2g14POjYQhPnIbRPEnNzvAe+Se3y0YeFOwYarEyFBHKHODGIPaCnXGH8gB9fgcp2SYtLaPKvXdNL44VeYGbD4+fvUcu/zkXqTSg=="+#LF$+
"-----END CERTIFICATE-----"
UseNetworkTLS(Key$, Cert$)
Con = CreateNetworkServer(#PB_Any, 20252, #PB_Network_TCP | #PB_Network_IPv4 | #PB_Network_TLSv1_3)
*Buffer = AllocateMemory(1000)
If Con
Timeout = 10000
OpenConsole("TCP Server with TLSv1_3")
PrintN("Server Running on port : 20252")
Repeat
ClientID = EventClient()
Select NetworkServerEvent()
Case #PB_NetworkEvent_Connect
PrintN("client connected ["+Str(ClientID)+"]")
Case #PB_NetworkEvent_Disconnect
PrintN("client disconnected ["+Str(ClientID)+"]")
Case #PB_NetworkEvent_Data
Debug "Data !"
PokeA(*Buffer, 0)
Debug ReceiveNetworkData(ClientID, *Buffer, 1000)
PrintN( "MsgReceived: "+PeekS(*Buffer, -1, #PB_UTF8) )
SendNetworkString(ClientID, "Well received !!!")
Case #PB_NetworkEvent_None
Delay(200)
Timeout - 1
EndSelect
Until Timeout = 0
CloseNetworkServer(Con)
Else
Debug "Can't create the server"
EndIf