You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
137 lines
4.0 KiB
137 lines
4.0 KiB
using System;
|
|
using System.Configuration;
|
|
using System.Threading;
|
|
using WebSocket4Net;
|
|
|
|
namespace Container.Common
|
|
{
|
|
public class WebSocketForFaceManage
|
|
{
|
|
private WebSocket websocket = null;
|
|
App app = ((App)System.Windows.Application.Current);
|
|
public delegate void WebSocketReceiveDelegate(string type, string message);
|
|
public static event WebSocketReceiveDelegate WebSocketReceiveEvent;
|
|
private Class_Log log = new Class_Log();
|
|
bool reconnect = false;
|
|
#region WebSocketClient
|
|
|
|
public void OpenWebSocket()
|
|
{
|
|
try
|
|
{
|
|
var ws = ConfigurationManager.AppSettings["websocketForFace"];
|
|
log.WriteLogFile(ws, "rich");
|
|
websocket = new WebSocket(ws);
|
|
websocket.Error += new EventHandler<SuperSocket.ClientEngine.ErrorEventArgs>(websocket_Error);
|
|
websocket.MessageReceived += new EventHandler<MessageReceivedEventArgs>(websocket_MessageReceived);
|
|
websocket.Open();
|
|
//websocket.Opened += new EventHandler(websocket_Opened);
|
|
websocket.Closed += new EventHandler(websocket_Closed);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
log.WriteLogFile(ex.ToString());
|
|
}
|
|
}
|
|
|
|
void websocket_Closed(object sender, EventArgs e)
|
|
{
|
|
if (!reconnect)
|
|
{
|
|
reconnect = true;
|
|
ReConnect();
|
|
}
|
|
}
|
|
|
|
public void CloseWebSocket()
|
|
{
|
|
if (websocket != null)
|
|
{
|
|
reconnect = true;
|
|
websocket.Close();
|
|
}
|
|
|
|
}
|
|
|
|
void websocket_MessageReceived(object sender, MessageReceivedEventArgs e)
|
|
{
|
|
log.WriteLogFile("进来了", "rich");
|
|
try
|
|
{
|
|
WebSocketReceiveEvent("richad", "");
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
log.WriteLogFile(ex.ToString(), "WebSocketLog");
|
|
|
|
}
|
|
}
|
|
|
|
void websocket_Error(object sender, SuperSocket.ClientEngine.ErrorEventArgs e)
|
|
{
|
|
|
|
log.WriteLogFile(e.Exception.Message + e.Exception.StackTrace, "WebSocketErrorLog");
|
|
//try
|
|
//{
|
|
// if (websocket != null)
|
|
// websocket.Close();
|
|
//}
|
|
//catch
|
|
//{
|
|
//}
|
|
//ReConnect();
|
|
}
|
|
|
|
/// <summary>
|
|
/// websocket重连
|
|
/// </summary>
|
|
private void ReConnect()
|
|
{
|
|
try
|
|
{
|
|
Action ac = new Action(() =>
|
|
{
|
|
while (true)
|
|
{
|
|
try
|
|
{
|
|
if (websocket.State == WebSocketState.Closed)
|
|
{
|
|
Thread.Sleep(30000);
|
|
|
|
if (websocket.State == WebSocketState.Closed)
|
|
websocket.Open();
|
|
}
|
|
|
|
if (websocket.State == WebSocketState.Open)
|
|
{
|
|
//reconnect = false;
|
|
break;
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
log.WriteLogFile(ex.ToString(), "WebSocketErrorLog");
|
|
}
|
|
finally
|
|
{
|
|
Thread.Sleep(3000);
|
|
}
|
|
|
|
|
|
}
|
|
});
|
|
ac.BeginInvoke((o) =>
|
|
{
|
|
reconnect = false;
|
|
}, null);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
log.WriteLogFile(ex.ToString(), "WebSocketErrorLog");
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
}
|
|
}
|
|
|