MFC - इंटरनेट प्रोग्रामिंग
Microsoft क्लाइंट और सर्वर दोनों अनुप्रयोगों के प्रोग्रामिंग के लिए कई एपीआई प्रदान करता है। इंटरनेट के लिए कई नए एप्लिकेशन लिखे जा रहे हैं, और जैसा कि प्रौद्योगिकियों, ब्राउज़र क्षमताओं और सुरक्षा विकल्पों में परिवर्तन होता है, नए प्रकार के एप्लिकेशन लिखे जाएंगे। आपका कस्टम एप्लिकेशन इंटरनेट पर जानकारी प्राप्त कर सकता है और डेटा प्रदान कर सकता है।
MFC एक वर्ग प्रदान करता है CSocket विंडोज़ सॉकेट के साथ नेटवर्क संचार कार्यक्रम लिखने के लिए।
यहाँ CSocket वर्ग के तरीकों की एक सूची दी गई है।
अनु क्रमांक। | नाम और विवरण |
---|---|
1 | Attach CS सॉकेट ऑब्जेक्ट के लिए एक सॉकेट हैंडल देता है। |
2 | CancelBlockingCall एक अवरुद्ध कॉल रद्द करता है जो वर्तमान में प्रगति पर है। |
3 | Create एक सॉकेट बनाता है। |
4 | FromHandle SOCKET हैंडल दिए जाने पर एक पॉइंटर को CSocket ऑब्जेक्ट पर लौटाता है। |
5 | IsBlocking निर्धारित करता है कि अवरुद्ध कॉल जारी है। |
एक एमएफएस एसडीआई एप्लिकेशन बनाकर हमें एक सरल उदाहरण में देखें।
Step 1 - नाम फ़ील्ड में MFCServer दर्ज करें और ठीक पर क्लिक करें।
Step 2 - उन्नत सुविधाओं टैब पर, विंडोज सॉकेट्स विकल्प की जांच करें।
Step 3 - प्रोजेक्ट बनने के बाद, एक नया MFC वर्ग CServerSocket जोड़ें।
Step 4 - बेस क्लास के रूप में सीएसकेट चुनें और फिनिश पर क्लिक करें।
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 () विधि में, सॉकेट बनाएं और पोर्ट निर्दिष्ट करें और फिर नीचे बताए अनुसार सुनो विधि को कॉल करें।
m_serverSocket.Create(6666);
m_serverSocket.Listen();
Step 9 - CMFCServerView हैडर फ़ाइल में निम्नलिखित हेडर फ़ाइल शामिल करें।
#include "MFCServerDoc.h"
Step 10 - सॉकेट क्लास से OnAccept फ़ंक्शन को ओवरराइड करें।
Step 11- वर्ग दृश्य में CServerSocket और गुण विंडो में हाइलाइट किए गए आइकन का चयन करें। अब, 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 वर्ग पर राइट-क्लिक करें और Add → AddFunction का चयन करें।
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 - एडवांस्ड फीचर्स टैब पर, ऊपर दिखाए गए अनुसार विंडोज सॉकेट्स विकल्प की जांच करें।
Step 3 - प्रोजेक्ट बन जाने के बाद, अपने संवाद बॉक्स को डिज़ाइन करें जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।
Step 4 - कनेक्ट और भेजें बटन के लिए घटना संचालकों जोड़ें।
Step 5- सभी तीन संपादन नियंत्रणों के लिए मूल्य चर जोड़ें। पोर्ट एडिट कंट्रोल के लिए, वेरिएबल टाइप UINT को चुनें।
Step 6 - संदेश जोड़ने और भेजने के लिए MFC वर्ग जोड़ें।
Step 7- हैडर फ़ाइल CMFCClientDemoApp क्लास में CClientSocket क्लास की हेडर फाइल शामिल करें और क्लास वेरिएबल जोड़ें। इसी तरह, CMFCClientDemoDlg हेडर फ़ाइल में वर्ग चर को भी जोड़ें।
CClientSocket m_clientSocket;
Step 8 - यहां कनेक्ट बटन इवेंट हैंडलर का कार्यान्वयन है।
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 - यहां सेंड बटन इवेंट हैंडलर का कार्यान्वयन है।
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- सबसे पहले सर्वर एप्लिकेशन और फिर क्लाइंट एप्लिकेशन को चलाएं। स्थानीय होस्ट आईपी और पोर्ट दर्ज करें और कनेक्ट पर क्लिक करें।
Step 11 - अब आपको सर्वर की तरफ का संदेश दिखाई देगा जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।