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;
}
}
}