using System; using System.Collections.Generic; using System.Text; using System.Threading; using System.Collections; using System.Net.NetworkInformation; using System.Runtime.InteropServices; using Newtonsoft.Json; //using Cosmos.BaseFrame; //using Cosmos.UserFrame; //using Cosmos.ServiceProvider; //using Cosmos.Common; /*-----------------------------------------------------------------------------------------------*/ // 설 명 : SC / HQ IRT Request (SC / 본부 IRT 요청) // 작 성 자 : // 변경 이력 : /*-----------------------------------------------------------------------------------------------*/ namespace NewPosInstaller { public class NetworkJSON //: INetworkJSON { //private SManager sManager = new SManager(); // 이 객체를 통해 업무 Service 호출 //private StateServer StateObject = (StateServer)StateServer.GetInstance(); // StateObject : StateServer Object (객체) //private PosStatus m_cPosStatus; // 기본정보 참조 //private DeviceStatus m_cDevStatus; // 장비정보 참조 /// /// Sending Socket (전송 소켓) /// private static TcpSocket m_IrtSocket = null; /// /// IP /// private string m_ServerIp = ""; /// /// Port /// private int m_ServerPort = 0; /// /// Recv Timeout /// private int m_ServerTimeout = 5000; /// --------------------------------------------------------------------------------------------- /// /// Constructor (생성자) /// /// --------------------------------------------------------------------------------------------- public NetworkJSON() { //m_cPosStatus = (PosStatus)StateObject.POS; // POS 기본정보 //m_cDevStatus = (DeviceStatus)StateObject.DEVICE; // POS 장치정보 } /// /// Get network online status with Ping check. (Ping체크로 network Online상태를 취득한다,) /// /// Ip address /// True : online false : Offline private int CheckNetworkOnline(string pHostAddress) { //Ping Check (Ping 체크) Ping pingSender = new Ping(); PingOptions optins = new PingOptions(); optins.DontFragment = true; string data = "aaa"; byte[] buffer = Encoding.ASCII.GetBytes(data); int timeout = 120; PingReply reply = pingSender.Send(pHostAddress, timeout, buffer, optins); if (reply.Status == IPStatus.Success) return ComLib.OK; else return ComLib.NG; } /* #region 암호화 편집 /// /// 암호화 위해 전문 편집 /// /// 평문 /// 암호문, 에러시 평문 리턴 private byte[] EncryptData(byte[] plainData) { int nNowPos = 0; //통신헤더전문편집 string[] aCommHead = new string[Column.COMM_HEADER.LEN.Length]; ItemColumn.ParseMessage(Column.COMM_HEADER.LEN, Column.COMM_HEADER.TYPE, plainData, ref nNowPos, ref aCommHead); string sPosNo = aCommHead[Column.COMM_HEADER.SEQ.PosNo].ToString(); //string sRegNo = aCommHead[Column.COMM_HEADER.SEQ.RegNo].ToString(); string sRegNo = ""; string sMsgLen = aCommHead[Column.COMM_HEADER.SEQ.MsgLen].ToString(); string sEncType = aCommHead[Column.COMM_HEADER.SEQ.EncType].ToString(); byte[] byteEncryptData = null; byte[] editedAllData = null; if (sEncType == "0") // "0" 평문 { //Tran헤더 포함 전문 데이터 byte[] tranBytes = new byte[plainData.Length - nNowPos]; Array.Copy(plainData, nNowPos, tranBytes, 0, plainData.Length - nNowPos); //암호화 byteEncryptData = AES.DynamicKeyEncrypt(sPosNo, sRegNo, tranBytes); int iMsgLen = nNowPos + byteEncryptData.Length; aCommHead[Column.COMM_HEADER.SEQ.MsgLen] = iMsgLen.ToString(); //공통헤더와 암호문 더해진 길이 aCommHead[Column.COMM_HEADER.SEQ.EncType] = "1"; //0:평문 1:암호화 string sChangedCommHeader = ItemColumn.MakeMessage(aCommHead, Column.COMM_HEADER.LEN, Column.COMM_HEADER.TYPE); byte[] byteCommHeader = Encoding.Default.GetBytes(sChangedCommHeader); editedAllData = new byte[iMsgLen]; Array.Copy(byteCommHeader, editedAllData, byteCommHeader.Length); Array.Copy(byteEncryptData, 0, editedAllData, byteCommHeader.Length, byteEncryptData.Length); return editedAllData; } else // "1" 암호문 { return plainData; } } #endregion #region 복호화 편집 /// /// 복호화 위해 전문 편집 /// /// /// private byte[] DecryptData(byte[] EncryptData) { int nNowPos = 0; //통신헤더전문편집 string[] aCommHead = new string[Column.COMM_HEADER.LEN.Length]; ItemColumn.ParseMessage(Column.COMM_HEADER.LEN, Column.COMM_HEADER.TYPE, EncryptData, ref nNowPos, ref aCommHead); string sPosNo = aCommHead[Column.COMM_HEADER.SEQ.PosNo].ToString(); //string sRegNo = aCommHead[Column.COMM_HEADER.SEQ.RegNo].ToString(); string sRegNo = ""; string sMsgLen = aCommHead[Column.COMM_HEADER.SEQ.MsgLen].ToString(); string sEncType = aCommHead[Column.COMM_HEADER.SEQ.EncType].ToString(); byte[] bytePlainData = null; byte[] editedAllData = null; if (sEncType == "1") //복호화 { //Tran헤더 포함 전문 데이터 byte[] tranBytes = new byte[EncryptData.Length - nNowPos]; Array.Copy(EncryptData, nNowPos, tranBytes, 0, tranBytes.Length); //복호화 bytePlainData = AES.DynamicKeyDecrypt(sPosNo, sRegNo, tranBytes); int iMsgLen = nNowPos + bytePlainData.Length; aCommHead[Column.COMM_HEADER.SEQ.MsgLen] = iMsgLen.ToString(); //공통헤더와 암호문 더해진 길이 aCommHead[Column.COMM_HEADER.SEQ.EncType] = "0"; //0:평문 1:암호화 string sChangedCommHeader = ItemColumn.MakeMessage(aCommHead, Column.COMM_HEADER.LEN, Column.COMM_HEADER.TYPE); byte[] byteCommHeader = Encoding.Default.GetBytes(sChangedCommHeader); editedAllData = new byte[byteCommHeader.Length + bytePlainData.Length]; Array.Copy(byteCommHeader, editedAllData, byteCommHeader.Length); Array.Copy(bytePlainData, 0, editedAllData, byteCommHeader.Length, bytePlainData.Length); return editedAllData; } else { return EncryptData; } } #endregion */ /// /// POS 마스터 요청 시 사용하는 Connect 함수 /// /// private int Connect(int iKeepTime = 5000) { int iReturn = ComLib.NG; try { m_IrtSocket = new TcpSocket(m_ServerIp, m_ServerPort, m_ServerTimeout); // Delay time to close connection is 5 sec. iReturn = m_IrtSocket.Connect(iKeepTime); } catch (Exception e) { ComLog.WriteLogFile(ComLib.LOG_ERROR, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, "NetworkJSON.Connect()", e.ToString()); } return iReturn; } private void Close() { m_IrtSocket.Close(); } /// /// IRT전문의 Send/Receive /// /// /// /// private int SendReceiveData(byte[] pSendData, ref byte[] pRecvData) { int nRecvLen = 0; int nStat = ComLib.NG; byte[] rRecvData = null; try { m_IrtSocket = new TcpSocket(m_ServerIp, m_ServerPort, m_ServerTimeout); // Data Send & Receive nRecvLen = m_IrtSocket.SendReceiveData(pSendData, ref rRecvData, m_ServerTimeout); if (nRecvLen > 0) { pRecvData = rRecvData; nStat = ComLib.OK; } else { pRecvData = null; } m_IrtSocket.Close(); } catch (Exception e) { if (m_IrtSocket != null) m_IrtSocket.Close(); ComLog.WriteLogFile(ComLib.LOG_ERROR, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, "NetworkJSON.SendReceiveData()", "NetworkIrt Error : ThreadNetworkIrt Exception !!! " + e.ToString()); } finally { } System.Threading.Thread.Sleep(100); return nStat; } /// /// IRT전문의 Send/Receive /// /// /// /// private int SendReceiveData(string pSendData, ref string pRecvData, bool bIsDmbIf = false) { int nRecvLen = 0; int nStat = ComLib.NG; string rRecvData = ""; try { m_IrtSocket = new TcpSocket(m_ServerIp, m_ServerPort, m_ServerTimeout); // Data Send & Receive //System.Diagnostics.Debug.Print("요청:" + pSendData); nRecvLen = m_IrtSocket.SendReceiveData(pSendData, ref rRecvData, m_ServerTimeout, bIsDmbIf); //System.Diagnostics.Debug.Print("응답:" + rRecvData); if (nRecvLen > 0) { pRecvData = rRecvData; nStat = ComLib.OK; } else { pRecvData = ""; nStat = nRecvLen; } m_IrtSocket.Close(); } catch (Exception e) { if (m_IrtSocket != null) m_IrtSocket.Close(); ComLog.WriteLogFile(ComLib.LOG_ERROR, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, "NetworkJSON.SendReceiveData()", "NetworkIrt Error : ThreadNetworkIrt Exception !!! " + e.ToString()); } finally { } System.Threading.Thread.Sleep(100); return nStat; } private int SendReceiveMstData(string pSendData, ref string pRecvData) { int nRecvLen = 0; int nStat = ComLib.NG; try { nRecvLen = m_IrtSocket.SendReceiveMstData(pSendData, ref pRecvData); if (nRecvLen > 0) { nStat = ComLib.OK; } } catch (Exception e) { ComLog.WriteLogFile(ComLib.LOG_ERROR, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, System.Reflection.MethodBase.GetCurrentMethod().Name + "()", e.ToString()); } return nStat; } /// /// IRT Byte로의 Send/Recv /// (공통헤더의 전문길이 0으로 세팅해서 송신. 자동 계산) /// /// public int IRTSendReceive(string sIP, int iPort, int iTimeOut, string sCommData, Hashtable htData, ref Hashtable htRecvData) { int nStat = 9; string sReturn = string.Empty; string sRecvCommHeader = string.Empty; string sRecvData = string.Empty; m_ServerIp = sIP; m_ServerPort = iPort; m_ServerTimeout = iTimeOut; string sJsonSendData = ""; string sJsonReceiveData = ""; try { if (m_ServerIp != "" && m_ServerPort != 0) { if (htData != null) { sJsonSendData = JsonConvert.SerializeObject(htData); //sJsonSendData 암호화 처리 ... Byte[] sBytTempBuff = Encoding.UTF8.GetBytes(sJsonSendData); string sDataLen = string.Format("{0:000000}", sBytTempBuff.Length); sCommData = sDataLen + sCommData.Substring(TcpSocket.COMM_MSGLEN); ComLog.WriteLogFile(ComLib.LOG_SOCK, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (Project Name (프로젝트명)) "NetworkJSON.IRTSendReceive()", ComLib.RPadH("[SEND" + ":" + m_ServerIp + ":" + m_ServerPort, 27) + "] " + sCommData + sJsonSendData); } // 3번 재시도 처리 추가 //Send Receive for (var i = 0; i < 3; i++) { nStat = SendReceiveData(sCommData + sJsonSendData, ref sJsonReceiveData); if (nStat == ComLib.OK) break; Thread.Sleep(300); } if (sJsonReceiveData != null && sJsonReceiveData != "") { sRecvCommHeader = sJsonReceiveData.Substring(0, TcpSocket.COMM_HEAD_LEN); sRecvData = sJsonReceiveData.Substring(TcpSocket.COMM_HEAD_LEN); //sJsonReceiveData 복호화 처리 ... htRecvData = JsonConvert.DeserializeObject(sRecvData); ComLog.WriteLogFile(ComLib.LOG_SOCK, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (Project Name (프로젝트명)) "NetworkJSON.IRTSendReceive()", ComLib.RPadH("[RECV" + ":" + m_ServerIp + ":" + m_ServerPort, 27) + "] " + sRecvCommHeader + sRecvData); } } } catch (Exception e) { ComLog.WriteLogFile(ComLib.LOG_ERROR, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, "NetworkJSON.IRTSendReceive()", e.ToString()); } return nStat; } /// /// 디지털메뉴보드 I/F용 send/receive /// /// /// /// /// /// /// /// public int DmbIRTSendReceive(string sIP, int iPort, int iTimeOut, string sCommData, Hashtable htData, ref string sRecvedData) { int nStat = 9; string sReturn = string.Empty; string sRecvCommHeader = string.Empty; string sRecvData = string.Empty; m_ServerIp = sIP; m_ServerPort = iPort; m_ServerTimeout = iTimeOut; string sJsonSendData = ""; string sJsonReceiveData = ""; try { if (m_ServerIp != "" && m_ServerPort != 0) { if (htData != null) { sJsonSendData = JsonConvert.SerializeObject(htData); //sJsonSendData 암호화 처리 ... ComLog.WriteLogFile(ComLib.LOG_SOCK, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (Project Name (프로젝트명)) "NetworkJSON.IRTSendReceive()", ComLib.RPadH("[SEND" + ":" + m_ServerIp + ":" + m_ServerPort, 27) + "] " + sCommData + sJsonSendData); } byte[] bytes = Encoding.UTF8.GetBytes(sCommData + sJsonSendData); string sUTF8String = Encoding.UTF8.GetString(bytes); //Send Receive //nStat = SendReceiveData(sCommData + sJsonSendData, ref sJsonReceiveData, true); nStat = SendReceiveData(sUTF8String, ref sJsonReceiveData, true); if (sJsonReceiveData != null && sJsonReceiveData != "") { sRecvCommHeader = sJsonReceiveData.Substring(0, 60); sRecvData = sJsonReceiveData.Substring(60); sRecvedData = sRecvCommHeader; ComLog.WriteLogFile(ComLib.LOG_SOCK, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (Project Name (프로젝트명)) "NetworkJSON.IRTSendReceive()", ComLib.RPadH("[RECV" + ":" + m_ServerIp + ":" + m_ServerPort, 27) + "] " + sRecvCommHeader + sRecvData); } } } catch (Exception e) { ComLog.WriteLogFile(ComLib.LOG_ERROR, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, "NetworkJSON.IRTSendReceive()", e.ToString()); } return nStat; } /// /// 마스터 요청을 위한 string으로의 send/receive /// /// /// /// /// /// /// /// public int MstIRTSendReceive(string sIp, int iPort, int iTimeOut, string sCommData, Hashtable htData, ref StringBuilder sbRecvData) { int nStat = ComLib.NG; string sRecvCommHeader = string.Empty; string sRecvData = string.Empty; try { m_ServerIp = sIp; m_ServerPort = iPort; m_ServerTimeout = iTimeOut; string sJsonSendData = string.Empty; string sJsonReceiveData = string.Empty; Hashtable htRecvData = null; sbRecvData = new StringBuilder(); nStat = Connect(-1); if(nStat == ComLib.OK) { while (true) { sJsonSendData = JsonConvert.SerializeObject(htData); //sJsonSendData 암호화 처리 ... Byte[] sBytTempBuff = Encoding.UTF8.GetBytes(sJsonSendData); string sDataLen = string.Format("{0:000000}", sBytTempBuff.Length); sCommData = sDataLen + sCommData.Substring(TcpSocket.COMM_MSGLEN); ComLog.WriteLogFile(ComLib.LOG_SOCK, ComLib.WARNING_LEVEL, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (Project Name (프로젝트명)) System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ComLib.RPadH("[SEND" + ":" + m_ServerIp + ":" + m_ServerPort, 27) + "] " + sCommData + sJsonSendData); // 전문 송신 nStat = SendReceiveMstData(sCommData + sJsonSendData, ref sJsonReceiveData); if (nStat == ComLib.OK) { ComLog.WriteLogFile(ComLib.LOG_SOCK, ComLib.WARNING_LEVEL, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (Project Name (프로젝트명)) System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ComLib.RPadH("[RECV" + ":" + m_ServerIp + ":" + m_ServerPort, 27) + "] " + sJsonReceiveData); if (sJsonReceiveData != null && sJsonReceiveData != string.Empty) { sRecvCommHeader = sJsonReceiveData.Substring(0, TcpSocket.COMM_HEAD_LEN); sRecvData = sJsonReceiveData.Substring(TcpSocket.COMM_HEAD_LEN); //sRecvData 복호화 처리 ... htRecvData = JsonConvert.DeserializeObject(sRecvData); if (int.Parse(htRecvData[Column.IQ_POSMASTER_RSP.DATA.Count].ToString().Trim()) != 0) { // StringBuilder에 추가 sbRecvData.Append(htRecvData[Column.IQ_POSMASTER_RSP.DATA.Data].ToString()); } else { break; } // 요청전문의 요청 코드 변경 htData[Column.IQ_POSMASTER_REQ.DATA.ProcCd] = "1"; } } else { return ComLib.NG1; } } nStat = ComLib.OK; } } catch (Exception e) { ComLog.WriteLogFile(ComLib.LOG_ERROR, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, "NetworkJSON.IRTSendReceive()", e.ToString()); } finally { Close(); } return nStat; } } }