websocket-sharp/Example2/Program.cs

132 lines
4.8 KiB
C#
Raw Normal View History

2012-08-04 14:51:31 +08:00
using System;
2013-07-19 16:29:58 +08:00
using System.Configuration;
using System.Security.Cryptography.X509Certificates;
2013-07-15 19:42:55 +08:00
using WebSocketSharp;
using WebSocketSharp.Net;
2012-08-06 13:34:39 +08:00
using WebSocketSharp.Server;
2012-08-04 14:51:31 +08:00
namespace Example2
{
public class Program
{
2014-10-03 14:32:50 +08:00
public static void Main (string[] args)
2012-08-04 14:51:31 +08:00
{
2015-11-27 16:38:37 +08:00
// Create a new instance of the WebSocketServer class.
//
2016-07-23 15:36:12 +08:00
// If you would like to provide the secure connection, you should create a new instance with
// the 'secure' parameter set to true, or a wss scheme WebSocket URL.
2015-11-27 16:38:37 +08:00
2013-07-19 16:29:58 +08:00
var wssv = new WebSocketServer (4649);
2015-07-15 16:38:06 +08:00
//var wssv = new WebSocketServer (5963, true);
//var wssv = new WebSocketServer (System.Net.IPAddress.Any, 4649);
//var wssv = new WebSocketServer (System.Net.IPAddress.Any, 5963, true);
//var wssv = new WebSocketServer (System.Net.IPAddress.IPv6Any, 4649);
//var wssv = new WebSocketServer (System.Net.IPAddress.IPv6Any, 5963, true);
//var wssv = new WebSocketServer ("ws://0.0.0.0:4649");
//var wssv = new WebSocketServer ("wss://0.0.0.0:5963");
//var wssv = new WebSocketServer ("ws://[::0]:4649");
//var wssv = new WebSocketServer ("wss://[::0]:5963");
//var wssv = new WebSocketServer (System.Net.IPAddress.Loopback, 4649);
//var wssv = new WebSocketServer (System.Net.IPAddress.Loopback, 5963, true);
//var wssv = new WebSocketServer (System.Net.IPAddress.IPv6Loopback, 4649);
//var wssv = new WebSocketServer (System.Net.IPAddress.IPv6Loopback, 5963, true);
2013-07-19 16:29:58 +08:00
//var wssv = new WebSocketServer ("ws://localhost:4649");
2015-07-15 16:38:06 +08:00
//var wssv = new WebSocketServer ("wss://localhost:5963");
//var wssv = new WebSocketServer ("ws://127.0.0.1:4649");
//var wssv = new WebSocketServer ("wss://127.0.0.1:5963");
//var wssv = new WebSocketServer ("ws://[::1]:4649");
//var wssv = new WebSocketServer ("wss://[::1]:5963");
2014-01-03 14:40:38 +08:00
#if DEBUG
2014-10-03 14:32:50 +08:00
// To change the logging level.
wssv.Log.Level = LogLevel.Trace;
2014-10-03 14:32:50 +08:00
// To change the wait time for the response to the WebSocket Ping or Close.
2016-07-23 15:36:12 +08:00
//wssv.WaitTime = TimeSpan.FromSeconds (2);
// Not to remove the inactive sessions periodically.
//wssv.KeepClean = false;
// To resolve to wait for socket in TIME_WAIT state.
//wssv.ReuseAddress = true;
2014-01-03 14:40:38 +08:00
#endif
2014-10-03 14:32:50 +08:00
/* To provide the secure connection.
var cert = ConfigurationManager.AppSettings["ServerCertFile"];
var passwd = ConfigurationManager.AppSettings["CertFilePassword"];
wssv.SslConfiguration.ServerCertificate = new X509Certificate2 (cert, passwd);
2014-01-03 14:40:38 +08:00
*/
2014-10-03 14:32:50 +08:00
/* To provide the HTTP Authentication (Basic/Digest).
2014-01-03 14:40:38 +08:00
wssv.AuthenticationSchemes = AuthenticationSchemes.Basic;
wssv.Realm = "WebSocket Test";
2014-10-08 09:38:00 +08:00
wssv.UserCredentialsFinder = id => {
2016-07-23 15:36:12 +08:00
var name = id.Name;
2014-11-18 12:26:10 +08:00
2016-07-23 15:36:12 +08:00
// Return user name, password, and roles.
return name == "nobita"
? new NetworkCredential (name, "password", "gunfighter")
: null; // If the user credentials aren't found.
};
*/
2014-10-03 14:32:50 +08:00
// Add the WebSocket services.
2013-07-19 16:29:58 +08:00
wssv.AddWebSocketService<Echo> ("/Echo");
wssv.AddWebSocketService<Chat> ("/Chat");
2014-10-03 14:32:50 +08:00
/* Add the WebSocket service with initializing.
wssv.AddWebSocketService<Chat> (
"/Chat",
2016-07-23 15:36:12 +08:00
() =>
new Chat ("Anon#") {
// To send the Sec-WebSocket-Protocol header that has a subprotocol name.
Protocol = "chat",
// To emit a WebSocket.OnMessage event when receives a ping.
EmitOnPing = true,
// To ignore the Sec-WebSocket-Extensions header.
IgnoreExtensions = true,
// To validate the Origin header.
OriginValidator = val => {
// Check the value of the Origin header, and return true if valid.
Uri origin;
return !val.IsNullOrEmpty ()
&& Uri.TryCreate (val, UriKind.Absolute, out origin)
&& origin.Host == "localhost";
},
// To validate the cookies.
CookiesValidator = (req, res) => {
// Check the cookies in 'req', and set the cookies to send to
// the client with 'res' if necessary.
foreach (Cookie cookie in req) {
cookie.Expired = true;
res.Add (cookie);
}
return true; // If valid.
}
}
2016-07-23 15:36:12 +08:00
);
*/
2013-07-19 16:29:58 +08:00
wssv.Start ();
if (wssv.IsListening) {
2014-10-08 09:38:00 +08:00
Console.WriteLine ("Listening on port {0}, and providing WebSocket services:", wssv.Port);
foreach (var path in wssv.WebSocketServices.Paths)
2014-03-14 19:56:14 +08:00
Console.WriteLine ("- {0}", path);
}
2012-08-04 14:51:31 +08:00
2014-03-14 19:56:14 +08:00
Console.WriteLine ("\nPress Enter key to stop the server...");
2013-07-19 16:29:58 +08:00
Console.ReadLine ();
2012-08-04 14:51:31 +08:00
2013-07-19 16:29:58 +08:00
wssv.Stop ();
2012-08-04 14:51:31 +08:00
}
}
}