MFC - Pemrograman Internet

Microsoft menyediakan banyak API untuk memprogram aplikasi klien dan server. Banyak aplikasi baru sedang ditulis untuk Internet, dan seiring dengan perubahan teknologi, kapabilitas browser, dan opsi keamanan, jenis aplikasi baru akan ditulis. Aplikasi kustom Anda dapat mengambil informasi dan menyediakan data di Internet.

MFC menyediakan kelas CSocket untuk menulis program komunikasi jaringan dengan Windows Sockets.

Berikut adalah daftar metode di kelas CSocket.

Sr.No. Nama & Deskripsi
1

Attach

Melampirkan pegangan SOCKET ke objek CSocket.

2

CancelBlockingCall

Membatalkan panggilan pemblokiran yang sedang berlangsung.

3

Create

Membuat soket.

4

FromHandle

Mengembalikan pointer ke objek CSocket, diberi pegangan SOCKET.

5

IsBlocking

Menentukan apakah panggilan pemblokiran sedang berlangsung.

Mari kita lihat contoh sederhana dengan membuat aplikasi MFS SDI.

Step 1 - Masukkan MFCServer di bidang nama dan klik OK.

Step 2 - Pada tab Advanced Features, periksa opsi soket Windows.

Step 3 - Setelah proyek dibuat, tambahkan CServerSocket kelas MFC baru.

Step 4 - Pilih CSocket sebagai kelas dasar dan klik Selesai.

Step 5 - Tambahkan lebih banyak CReceivingSocket kelas MFC.

Step 6 - CRecevingSocket akan menerima pesan masuk dari klien.

Di CMFCServerApp, file header menyertakan file berikut -

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

Step 7 - Tambahkan dua variabel kelas berikut di kelas CMFCServerApp.

CServerSocket m_serverSocket;
CMFCServerView m_pServerView;

Step 8 - Dalam metode CMFCServerApp :: InitInstance (), buat soket dan tentukan portnya, lalu panggil metode Listen seperti yang ditunjukkan di bawah ini.

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

Step 9 - Sertakan file header berikut di file header CMFCServerView.

#include "MFCServerDoc.h"

Step 10 - Mengesampingkan fungsi OnAccept dari kelas Socket.

Step 11- Pilih CServerSocket dalam tampilan kelas dan ikon yang disorot di jendela Properties. Sekarang, Tambahkan OnAccept. Berikut adalah implementasi fungsi 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 - Tambahkan fungsi 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 - Tambahkan fungsi OnReceive () di kelas CReceivingSocket.

Klik kanan pada kelas CMFCServerView di explorer solusi dan pilih Add → AddFunction.

Step 14 - Masukkan informasi yang disebutkan di atas dan klik selesai.

Step 15 - Tambahkan variabel CStringArray berikut di file header CMFCServerView.

CStringArray m_msgArray;

Step 16 - Berikut implementasi fungsi AddMsg ().

void CMFCServerView::AddMsg(CString message) {

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

Step 17 - Perbarui konstruktor seperti yang ditunjukkan pada kode berikut.

CMFCServerView::CMFCServerView() {

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

Step 18 - Berikut implementasi fungsi OnDraw () yang menampilkan pesan.

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- Sisi server sekarang telah selesai. Ini akan menerima pesan dari klien.

Buat Aplikasi Sisi Klien

Step 1 - Mari kita buat aplikasi berbasis dialog MFC baru untuk aplikasi sisi klien.

Step 2 - Pada tab Advanced Features, periksa opsi soket Windows seperti yang ditunjukkan di atas.

Step 3 - Setelah proyek dibuat, desain kotak dialog Anda seperti yang ditunjukkan pada gambar berikut.

Step 4 - Tambahkan penangan acara untuk tombol Hubungkan dan Kirim.

Step 5- Tambahkan variabel nilai untuk ketiga kontrol edit. Untuk kontrol edit port, pilih tipe variabel UINT.

Step 6 - Tambahkan kelas MFC untuk menghubungkan dan mengirim pesan.

Step 7- Sertakan file header kelas CClientSocket di file header kelas CMFCClientDemoApp dan tambahkan variabel kelas. Demikian pula, tambahkan juga variabel kelas di file header CMFCClientDemoDlg.

CClientSocket m_clientSocket;

Step 8 - Berikut adalah implementasi event handler tombol 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 - Berikut adalah implementasi event handler tombol 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- Pertama-tama, jalankan aplikasi Server, lalu aplikasi klien. Masukkan ip dan port host lokal dan klik Hubungkan.

Step 11 - Sekarang Anda akan melihat pesan di sisi Server seperti yang ditunjukkan pada gambar berikut.