LineConnect.cs 7.2 KB
using OnlineStore.Common;
using System;
using System.Collections.Generic;
using System.Linq; 
using System.Text;
using System.Threading;

namespace OnlineStore.DeviceLibrary
{
    public class LineConnect
    {
        private static int ClientKeepSecond = 10;
        private static TcpClient client = null;
        public static  List<string> WaitInStoreList = new List<string>();
        public static void StartConnect()
        {
            string lineServer = ConfigAppSettings.GetValue(Setting_Init.LineServerIp);
            int linePort = ConfigAppSettings.GetIntValue(Setting_Init.LineServerPort);
            if (lineServer.Equals(""))
            {
                LogUtil.error("未配置流水线地址,不需要连接");
                return;
            } 
            client = new TcpClient();
            
            bool result = client.StartConnect(lineServer, linePort, HandlerMsg,2000);
          
        }

        public static void StopConnect()
        {
            if (client != null)
            {
                client.close();
            }
        }
        private static int seq = 1;

        public static int nextSeq()
        {
            if (seq.Equals(Int32.MaxValue))
            {
                LogUtil.info("seq当前值:" + seq + ",重置seq=0");
                seq = 0;
            }
            Interlocked.Increment(ref seq);
            return seq;
        }

        public static void SendHeart(StoreSendBean store)
        {
            if (client == null)
            {
                return;
            }
            try
            {
                store.Cmd = cmd_heart; 
                string heartMsg = ToParamStr(store);
                client.send(heartMsg);
            } catch (Exception ex)
            {
                LogUtil.error("SendHeart 出错:" + ex.ToString());
            }
        }

        public static void OutStoreEnd(StoreSendBean store)
        {
            if (client == null)
            {
                return;
            }
            try
            {
                store.Cmd = cmd_outend; 
                string msg = ToParamStr(store);
                LogUtil.info("OutStoreEnd:" + msg);
                client.send(msg);
            }
            catch (Exception ex)
            {
                LogUtil.error("OutStoreEnd 出错:" + ex.ToString());
            }
        }
        private static string ToParamStr(StoreSendBean store)
        {
            return JsonHelper.SerializeObject(store)+"\r";
        }

        private static string ToParamStr(List<object> paramList)
        {
            string result = "";
            foreach (object str in paramList)
            {
                result += str + cmd_spilt.ToString();
            }
            return result + "\r";
        }
        private static void HandlerMsg(string message)
        {
            try
            {
                message = message.Replace("\r", "");
                StoreReviceBean reviceInfo = JsonHelper.DeserializeJsonToObject<StoreReviceBean>(message);
                //string[] msgArray = message.Split(cmd_spilt);
                if (reviceInfo == null)
                {
                    LogUtil.debug("收到消息:" + message + ",解析失败");
                }
                else
                {
                    string cmd = reviceInfo.Cmd; 
                    CanOutStore = reviceInfo.CanOutStore.Equals(1);
                    LastUpdateTime = DateTime.Now;
                    if (cmd.Equals(cmd_startIn))
                    {
                        LogUtil.info("收到流水线入库消息:" + message);
                        //string posId = reviceInfo.PosId;
                        //string plateH = reviceInfo.PlateH
                        //string plateW = msgArray[4];
                        //string code = msgArray[5];
                        StoreManager.Store.ReviceLineInStoreCMD(reviceInfo.PosId,reviceInfo.PlateH,reviceInfo.PlateW,reviceInfo.WareCode);
                    }
                    else if (cmd.Equals(cmd_updateDebug))
                    {
                        int isDebug = reviceInfo.IsDebug;

                        LogUtil.info("收到流水线更改调试状态=" + isDebug);
                        StoreManager.Store.IsDebug = isDebug.Equals(1) ? true : false;
                        ConfigAppSettings.SaveValue(Setting_Init.IsInDebug, isDebug);
                        LogUtil.info("切换调试状态= " + isDebug + ";");
                    }
                    else if (cmd.Equals(cmd_checStartIn))
                    {
                        LogUtil.info("收到流水线入库库位验证消息:" + message);
                   
                        bool result = StoreManager.Store.ReviceLineCheckInStoreCMD(reviceInfo.PosId, reviceInfo.PlateH, reviceInfo.PlateW, reviceInfo.WareCode);
                        if (result)
                        {
                            LineConnect.WaitInStoreList.Add(reviceInfo.PosId);
                        }
                    }

                }
            }
            catch (Exception ex)
            {
                LogUtil.error("处理流水线消息【"+ message +"】出错:" +ex.ToString() );
            }
        }
        public static char cmd_spilt = ';';
        public  static string cmd_heart = "heart";
        private static string cmd_outend = "outend";
        private static string cmd_startIn = "starIn";
        private static string cmd_updateDebug = "updateDebug";
        private static bool CanOutStore = false;
        public static DateTime LastUpdateTime = new DateTime(0);
        public static string cmd_checStartIn = "cmd_checStartIn";
        public static bool IsConnect()
        { 
            if (client == null)
            {
                return false;
            }
            if (client.IsRun()&& client.IsConnected())
            {
                return true;
            }
            return false ;
        }

        public static bool CanStartOut()
        {
            TimeSpan span = DateTime.Now - LastUpdateTime;
            if (span.TotalSeconds < ClientKeepSecond && CanOutStore)
            {
                return true;
            }
            return false;
        }
    }
    public class StoreReviceBean
    {
        public string Cmd = "";
        public int CanOutStore = 0;
        public string PosId = "";
        public string PlateH = "0";
        public string PlateW = "0";
        public string WareCode = "";
        public int IsDebug = 0;
    }
    public class StoreSendBean
    {
        public StoreSendBean(int id, string cid, int ss, int runs, int doorHasTray, int alarmType)
        {
            this.StoreId = id;
            this.Cid = cid;
            this.SStatus = ss;
            this.SRunStatus = runs;
            this.DoorHasTray = doorHasTray;
            this.AlarmType = alarmType;
            this.Seq = LineConnect.nextSeq();
        }
        public string Cmd =LineConnect. cmd_heart;
        public int StoreId = 0;
        public string Cid = "";
        public int Seq = 0;
        public int SStatus = 0;
        public int SRunStatus = 0;
        public int DoorHasTray = 0;
        public int AlarmType = 0;
        public string PosId = "";
        public string PlateH = "0";
        public string PlateW = "0";
    }
}