ClientDlg.cpp 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. // ClientDlg.cpp : implementation file
  2. //
  3. #include "stdafx.h"
  4. #include "Client.h"
  5. #include "ClientDlg.h"
  6. #include "afxdialogex.h"
  7. // CClientDlg dialog
  8. #define DEFAULT_CONTENT _T("text to be sent")
  9. #define DEFAULT_ADDRESS _T("127.0.0.1")
  10. #define DEFAULT_PORT _T("5555")
  11. CClientDlg::CClientDlg(CWnd* pParent /*=NULL*/)
  12. : CDialogEx(CClientDlg::IDD, pParent), m_Client(this)
  13. {
  14. m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
  15. }
  16. void CClientDlg::DoDataExchange(CDataExchange* pDX)
  17. {
  18. CDialogEx::DoDataExchange(pDX);
  19. DDX_Control(pDX, IDC_CONTENT, m_Content);
  20. DDX_Control(pDX, IDC_SEND, m_Send);
  21. DDX_Control(pDX, IDC_INFO, m_Info);
  22. DDX_Control(pDX, IDC_ADDRESS, m_Address);
  23. DDX_Control(pDX, IDC_PORT, m_Port);
  24. DDX_Control(pDX, IDC_ASYNC, m_Async);
  25. DDX_Control(pDX, IDC_START, m_Start);
  26. DDX_Control(pDX, IDC_STOP, m_Stop);
  27. }
  28. BEGIN_MESSAGE_MAP(CClientDlg, CDialogEx)
  29. ON_WM_PAINT()
  30. ON_WM_QUERYDRAGICON()
  31. ON_EN_CHANGE(IDC_CONTENT, &CClientDlg::OnEnChangeContent)
  32. ON_BN_CLICKED(IDC_SEND, &CClientDlg::OnBnClickedSend)
  33. ON_BN_CLICKED(IDC_START, &CClientDlg::OnBnClickedStart)
  34. ON_BN_CLICKED(IDC_STOP, &CClientDlg::OnBnClickedStop)
  35. ON_MESSAGE(USER_INFO_MSG, OnUserInfoMsg)
  36. ON_WM_VKEYTOITEM()
  37. END_MESSAGE_MAP()
  38. // CClientDlg message handlers
  39. BOOL CClientDlg::OnInitDialog()
  40. {
  41. CDialogEx::OnInitDialog();
  42. // Set the icon for this dialog. The framework does this automatically
  43. // when the application's main window is not a dialog
  44. SetIcon(m_hIcon, TRUE); // Set big icon
  45. SetIcon(m_hIcon, FALSE); // Set small icon
  46. // TODO: Add extra initialization here
  47. m_Content.SetWindowText(DEFAULT_CONTENT);
  48. m_Address.SetWindowText(DEFAULT_ADDRESS);
  49. m_Port.SetWindowText(DEFAULT_PORT);
  50. m_Async.SetCheck(BST_CHECKED);
  51. ::SetMainWnd(this);
  52. ::SetInfoList(&m_Info);
  53. SetAppState(ST_STOPPED);
  54. m_bAsyncConn = FALSE;
  55. return TRUE; // return TRUE unless you set the focus to a control
  56. }
  57. // If you add a minimize button to your dialog, you will need the code below
  58. // to draw the icon. For MFC applications using the document/view model,
  59. // this is automatically done for you by the framework.
  60. void CClientDlg::OnPaint()
  61. {
  62. if (IsIconic())
  63. {
  64. CPaintDC dc(this); // device context for painting
  65. SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
  66. // Center icon in client rectangle
  67. int cxIcon = GetSystemMetrics(SM_CXICON);
  68. int cyIcon = GetSystemMetrics(SM_CYICON);
  69. CRect rect;
  70. GetClientRect(&rect);
  71. int x = (rect.Width() - cxIcon + 1) / 2;
  72. int y = (rect.Height() - cyIcon + 1) / 2;
  73. // Draw the icon
  74. dc.DrawIcon(x, y, m_hIcon);
  75. }
  76. else
  77. {
  78. CDialogEx::OnPaint();
  79. }
  80. }
  81. // The system calls this function to obtain the cursor to display while the user drags
  82. // the minimized window.
  83. HCURSOR CClientDlg::OnQueryDragIcon()
  84. {
  85. return static_cast<HCURSOR>(m_hIcon);
  86. }
  87. BOOL CClientDlg::PreTranslateMessage(MSG* pMsg)
  88. {
  89. if (
  90. pMsg->message == WM_KEYDOWN
  91. &&( pMsg->wParam == VK_ESCAPE
  92. || pMsg->wParam == VK_CANCEL
  93. || pMsg->wParam == VK_RETURN
  94. ))
  95. return TRUE;
  96. return CDialog::PreTranslateMessage(pMsg);
  97. }
  98. void CClientDlg::SetAppState(EnAppState state)
  99. {
  100. m_enState = state;
  101. if(this->GetSafeHwnd() == nullptr)
  102. return;
  103. m_Async.EnableWindow(m_enState == ST_STOPPED);
  104. m_Start.EnableWindow(m_enState == ST_STOPPED);
  105. m_Stop.EnableWindow(m_enState == ST_STARTED);
  106. m_Send.EnableWindow(m_enState == ST_STARTED && m_Content.GetWindowTextLength() > 0);
  107. m_Address.EnableWindow(m_enState == ST_STOPPED);
  108. m_Port.EnableWindow(m_enState == ST_STOPPED);
  109. }
  110. void CClientDlg::OnEnChangeContent()
  111. {
  112. m_Send.EnableWindow(m_enState == ST_STARTED && m_Content.GetWindowTextLength() > 0);
  113. }
  114. void CClientDlg::OnBnClickedSend()
  115. {
  116. USES_CONVERSION;
  117. CString strContent;
  118. m_Content.GetWindowText(strContent);
  119. LPSTR lpszContent = T2A((LPTSTR)(LPCTSTR)strContent);
  120. int iLen = (int)strlen(lpszContent);
  121. if(m_Client.Send((LPBYTE)lpszContent, iLen))
  122. ::LogSend(m_Client.GetConnectionID(), strContent);
  123. else
  124. ::LogSendFail(m_Client.GetConnectionID(), ::GetLastError(), ::GetSocketErrorDesc(SE_DATA_SEND));
  125. }
  126. void CClientDlg::OnBnClickedStart()
  127. {
  128. SetAppState(ST_STARTING);
  129. g_SSL.Cleanup();
  130. if(!g_SSL.Initialize(SSL_SM_CLIENT, g_c_iVerifyMode, g_c_lpszPemCertFile, g_c_lpszPemKeyFile, g_c_lpszKeyPasswod, g_c_lpszCAPemCertFileOrPath))
  131. {
  132. ::LogClientStartFail(::GetLastError(), _T("initialize SSL env fail"));
  133. SetAppState(ST_STOPPED);
  134. return;
  135. }
  136. CString strAddress;
  137. CString strPort;
  138. m_Address.GetWindowText(strAddress);
  139. m_Port.GetWindowText(strPort);
  140. USHORT usPort = (USHORT)_ttoi(strPort);
  141. m_bAsyncConn = m_Async.GetCheck();
  142. ::LogClientStarting(strAddress, usPort);
  143. if(m_Client.Start(strAddress, usPort, m_bAsyncConn))
  144. {
  145. }
  146. else
  147. {
  148. ::LogClientStartFail(m_Client.GetLastError(), m_Client.GetLastErrorDesc());
  149. SetAppState(ST_STOPPED);
  150. }
  151. }
  152. void CClientDlg::OnBnClickedStop()
  153. {
  154. SetAppState(ST_STOPPING);
  155. if(m_Client.Stop())
  156. ::LogClientStopping(m_Client.GetConnectionID());
  157. else
  158. ASSERT(FALSE);
  159. }
  160. int CClientDlg::OnVKeyToItem(UINT nKey, CListBox* pListBox, UINT nIndex)
  161. {
  162. if(nKey == 'C')
  163. pListBox->ResetContent();
  164. return __super::OnVKeyToItem(nKey, pListBox, nIndex);
  165. }
  166. LRESULT CClientDlg::OnUserInfoMsg(WPARAM wp, LPARAM lp)
  167. {
  168. info_msg* msg = (info_msg*)wp;
  169. ::LogInfoMsg(msg);
  170. return 0;
  171. }
  172. EnHandleResult CClientDlg::OnConnect(IClient* pClient)
  173. {
  174. TCHAR szAddress[40];
  175. int iAddressLen = sizeof(szAddress) / sizeof(TCHAR);
  176. USHORT usPort;
  177. pClient->GetLocalAddress(szAddress, iAddressLen, usPort);
  178. ::PostOnConnect(pClient->GetConnectionID(), szAddress, usPort);
  179. return HR_OK;
  180. }
  181. EnHandleResult CClientDlg::OnHandShake(IClient* pClient)
  182. {
  183. ::PostOnHandShake(pClient->GetConnectionID());
  184. SetAppState(ST_STARTED);
  185. return HR_OK;
  186. }
  187. EnHandleResult CClientDlg::OnSend(IClient* pClient, const BYTE* pData, int iLength)
  188. {
  189. ::PostOnSend(pClient->GetConnectionID(), pData, iLength);
  190. return HR_OK;
  191. }
  192. EnHandleResult CClientDlg::OnReceive(IClient* pClient, const BYTE* pData, int iLength)
  193. {
  194. ::PostOnReceive(pClient->GetConnectionID(), pData, iLength);
  195. return HR_OK;
  196. }
  197. EnHandleResult CClientDlg::OnClose(IClient* pClient, EnSocketOperation enOperation, int iErrorCode)
  198. {
  199. iErrorCode == SE_OK ? ::PostOnClose(pClient->GetConnectionID()) :
  200. ::PostOnError(pClient->GetConnectionID(), enOperation, iErrorCode) ;
  201. SetAppState(ST_STOPPED);
  202. return HR_OK;
  203. }