MFC-인터넷 프로그래밍

Microsoft는 클라이언트 및 서버 응용 프로그램을 프로그래밍하기위한 많은 API를 제공합니다. 인터넷 용으로 많은 새로운 응용 프로그램이 작성되고 있으며 기술, 브라우저 기능 및 보안 옵션이 변경됨에 따라 새로운 유형의 응용 프로그램이 작성 될 것입니다. 사용자 지정 응용 프로그램은 정보를 검색하고 인터넷에서 데이터를 제공 할 수 있습니다.

MFC는 클래스를 제공합니다 CSocket Windows 소켓을 사용하여 네트워크 통신 프로그램을 작성합니다.

다음은 CSocket 클래스의 메서드 목록입니다.

Sr. 아니. 이름 및 설명
1

Attach

CSocket 개체에 SOCKET 핸들을 연결합니다.

2

CancelBlockingCall

현재 진행중인 차단 통화를 취소합니다.

Create

소켓을 만듭니다.

4

FromHandle

SOCKET 핸들이 지정된 경우 CSocket 개체에 대한 포인터를 반환합니다.

5

IsBlocking

차단 호출이 진행 중인지 확인합니다.

MFS SDI 애플리케이션을 생성하여 간단한 예를 살펴 보겠습니다.

Step 1 − 이름 필드에 MFCServer를 입력하고 확인을 클릭합니다.

Step 2 − 고급 기능 탭에서 Windows 소켓 옵션을 선택하십시오.

Step 3 − 프로젝트가 생성되면 새로운 MFC 클래스 CServerSocket을 추가합니다.

Step 4 − CSocket을 기본 클래스로 선택하고 마침을 클릭합니다.

Step 5 − 더 많은 MFC 클래스 CReceivingSocket을 추가합니다.

Step 6 − CRecevingSocket은 클라이언트로부터 수신 메시지를 수신합니다.

CMFCServerApp에서 헤더 파일에는 다음 파일이 포함됩니다.

#include "ServerSocket.h"
#include "MFCServerView.h"

Step 7 − CMFCServerApp 클래스에 다음 두 개의 클래스 변수를 추가합니다.

CServerSocket m_serverSocket;
CMFCServerView m_pServerView;

Step 8 − CMFCServerApp :: InitInstance () 메서드에서 소켓을 생성하고 포트를 지정한 후 아래와 같이 Listen 메서드를 호출합니다.

m_serverSocket.Create(6666);
m_serverSocket.Listen();

Step 9 − CMFCServerView 헤더 파일에 다음 헤더 파일을 포함합니다.

#include "MFCServerDoc.h"

Step 10 − Socket 클래스에서 OnAccept 함수를 재정의합니다.

Step 11− 클래스보기에서 CServerSocket을 선택하고 속성 창에서 강조 표시된 아이콘을 선택합니다. 이제 Add OnAccept. 다음은 OnAccept 함수의 구현입니다.

void CServerSocket::OnAccept(int nErrorCode) {

   // TODO: Add your specialized code here and/or call the base class
   AfxMessageBox(L"Connection accepted");
   CSocket::OnAccept(nErrorCode);
}

Step 12 − OnReceive () 함수를 추가합니다.

void CServerSocket::OnReceive(int nErrorCode) { 
   
   // TODO: Add your specialized code here and/or call the base class
   AfxMessageBox(L"Data Received");
   CSocket::OnReceive(nErrorCode);
}

Step 13 − CReceivingSocket 클래스에 OnReceive () 함수를 추가합니다.

솔루션 탐색기에서 CMFCServerView 클래스를 마우스 오른쪽 단추로 클릭하고 추가 → 함수 추가를 선택합니다.

Step 14 − 위에서 언급 한 정보를 입력하고 마침을 클릭합니다.

Step 15 − CMFCServerView 헤더 파일에 다음 CStringArray 변수를 추가합니다.

CStringArray m_msgArray;

Step 16 − 다음은 AddMsg () 함수의 구현입니다.

void CMFCServerView::AddMsg(CString message) {

   m_msgArray.Add(message);
   Invalidate();
}

Step 17 − 다음 코드와 같이 생성자를 업데이트합니다.

CMFCServerView::CMFCServerView() {

   ((CMFCServerApp*)AfxGetApp()) -> m_pServerView = this;
}

Step 18 − 다음은 메시지를 표시하는 OnDraw () 함수의 구현입니다.

void CMFCServerView::OnDraw(CDC* pDC) {

   int y = 100;
   for (int i = 0; m_msgArray.GetSize(); i++) {
   
      pDC->TextOut(100, y, m_msgArray.GetAt(i));
      y += 50;
   }
   CMFCServerDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

Step 19− 이제 서버 측이 완료되었습니다. 클라이언트로부터 메시지를받습니다.

클라이언트 측 애플리케이션 생성

Step 1 − 클라이언트 측 응용 프로그램을위한 새로운 MFC 대화 상자 기반 응용 프로그램을 만들어 보겠습니다.

Step 2 − 고급 기능 탭에서 위와 같이 Windows 소켓 옵션을 확인하십시오.

Step 3 − 프로젝트가 생성되면 다음 스냅 샷과 같이 대화 상자를 디자인합니다.

Step 4 − 연결 및 전송 버튼에 대한 이벤트 핸들러를 추가합니다.

Step 5− 세 가지 편집 컨트롤 모두에 대한 값 변수를 추가합니다. 포트 편집 제어의 경우 변수 유형 UINT를 선택합니다.

Step 6 − 연결 및 메시지 전송을위한 MFC 클래스를 추가합니다.

Step 7− CMFCClientDemoApp 헤더 파일에 CClientSocket 클래스의 헤더 파일을 포함하고 클래스 변수를 추가합니다. 마찬가지로 CMFCClientDemoDlg 헤더 파일에도 클래스 변수를 추가합니다.

CClientSocket m_clientSocket;

Step 8 − 다음은 Connect 버튼 이벤트 핸들러의 구현입니다.

void CMFCClientDemoDlg::OnBnClickedButtonConnect() {

   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   m_clientSocket.Create();
   if (m_clientSocket.Connect(m_ipAddress, m_port)) {
      AfxMessageBox(L"Connection Successfull");
   }else {
      AfxMessageBox(L"Connection Failed");
   }
   DWORD error = GetLastError();
}

Step 9 − 다음은 Send 버튼 이벤트 핸들러의 구현입니다.

void CMFCClientDemoDlg::OnBnClickedButtonSend() {

   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   if (m_clientSocket.Send(m_message.GetBuffer(m_message.GetLength()), m_message.GetLength())) {
   
   }else {
      AfxMessageBox(L"Failed to send message");
   }
}

Step 10− 먼저 서버 응용 프로그램을 실행 한 다음 클라이언트 응용 프로그램을 실행하십시오. 로컬 호스트 IP 및 포트를 입력하고 연결을 클릭합니다.

Step 11 − 이제 다음 스냅 샷과 같이 서버 측에 메시지가 표시됩니다.