[Modify] Polish it

This commit is contained in:
sta 2016-07-23 16:36:12 +09:00
parent ae4d764355
commit 40b23a6aea

View File

@ -13,8 +13,8 @@ namespace Example2
{ {
// Create a new instance of the WebSocketServer class. // Create a new instance of the WebSocketServer class.
// //
// If you would like to provide the secure connection, you should create the instance with // If you would like to provide the secure connection, you should create a new instance with
// the 'secure' parameter set to true, or the wss scheme WebSocket URL. // the 'secure' parameter set to true, or a wss scheme WebSocket URL.
var wssv = new WebSocketServer (4649); var wssv = new WebSocketServer (4649);
//var wssv = new WebSocketServer (5963, true); //var wssv = new WebSocketServer (5963, true);
@ -50,7 +50,13 @@ namespace Example2
wssv.Log.Level = LogLevel.Trace; wssv.Log.Level = LogLevel.Trace;
// To change the wait time for the response to the WebSocket Ping or Close. // To change the wait time for the response to the WebSocket Ping or Close.
wssv.WaitTime = TimeSpan.FromSeconds (2); //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;
#endif #endif
/* To provide the secure connection. /* To provide the secure connection.
var cert = ConfigurationManager.AppSettings["ServerCertFile"]; var cert = ConfigurationManager.AppSettings["ServerCertFile"];
@ -62,21 +68,15 @@ namespace Example2
wssv.AuthenticationSchemes = AuthenticationSchemes.Basic; wssv.AuthenticationSchemes = AuthenticationSchemes.Basic;
wssv.Realm = "WebSocket Test"; wssv.Realm = "WebSocket Test";
wssv.UserCredentialsFinder = id => { wssv.UserCredentialsFinder = id => {
var name = id.Name; var name = id.Name;
// Return user name, password, and roles. // Return user name, password, and roles.
return name == "nobita" return name == "nobita"
? new NetworkCredential (name, "password", "gunfighter") ? new NetworkCredential (name, "password", "gunfighter")
: null; // If the user credentials aren't found. : null; // If the user credentials aren't found.
}; };
*/ */
// Not to remove the inactive sessions periodically.
//wssv.KeepClean = false;
// To resolve to wait for socket in TIME_WAIT state.
//wssv.ReuseAddress = true;
// Add the WebSocket services. // Add the WebSocket services.
wssv.AddWebSocketService<Echo> ("/Echo"); wssv.AddWebSocketService<Echo> ("/Echo");
wssv.AddWebSocketService<Chat> ("/Chat"); wssv.AddWebSocketService<Chat> ("/Chat");
@ -84,33 +84,35 @@ namespace Example2
/* Add the WebSocket service with initializing. /* Add the WebSocket service with initializing.
wssv.AddWebSocketService<Chat> ( wssv.AddWebSocketService<Chat> (
"/Chat", "/Chat",
() => new Chat ("Anon#") { () =>
// To send the Sec-WebSocket-Protocol header that has a subprotocol name. new Chat ("Anon#") {
Protocol = "chat", // To send the Sec-WebSocket-Protocol header that has a subprotocol name.
// To emit a WebSocket.OnMessage event when receives a ping. Protocol = "chat",
EmitOnPing = true, // To emit a WebSocket.OnMessage event when receives a ping.
// To ignore the Sec-WebSocket-Extensions header. EmitOnPing = true,
IgnoreExtensions = true, // To ignore the Sec-WebSocket-Extensions header.
// To validate the Origin header. IgnoreExtensions = true,
OriginValidator = val => { // To validate the Origin header.
// Check the value of the Origin header, and return true if valid. OriginValidator = val => {
Uri origin; // Check the value of the Origin header, and return true if valid.
return !val.IsNullOrEmpty () && Uri origin;
Uri.TryCreate (val, UriKind.Absolute, out origin) && return !val.IsNullOrEmpty ()
origin.Host == "localhost"; && Uri.TryCreate (val, UriKind.Absolute, out origin)
}, && origin.Host == "localhost";
// To validate the Cookies. },
CookiesValidator = (req, res) => { // To validate the cookies.
// Check the Cookies in 'req', and set the Cookies to send to the client with 'res' CookiesValidator = (req, res) => {
// if necessary. // Check the cookies in 'req', and set the cookies to send to
foreach (Cookie cookie in req) { // the client with 'res' if necessary.
cookie.Expired = true; foreach (Cookie cookie in req) {
res.Add (cookie); cookie.Expired = true;
} res.Add (cookie);
}
return true; // If valid. return true; // If valid.
}
} }
}); );
*/ */
wssv.Start (); wssv.Start ();