• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            面對現實,超越自己
            逆水行舟,不進則退
            posts - 269,comments - 32,trackbacks - 0
            MFC socket的使用方法

            服務器端:
            在.h文件中。
             1 struct ListeningThreadStruct
             2 {
             3     CString sSaveDir;
             4     int     nListenPort;
             5 };
             6 UINT ListeningThreadProc(LPVOID lparam);
             7 struct FileTransferThreadStruct
             8 {
             9     CString sSaveDir;
            10     SOCKET  hSOCKET;
            11 };
            12 
            13 UINT FileTransferThread(LPVOID lparam);

            在.cpp文件中。
             1 UINT CSocketFun::ListeningThreadProc(LPVOID lparam)
             2 {
             3     ListeningThreadStruct *pPara = (ListeningThreadStruct*)lparam;
             4     int nListenPort  = pPara->nListenPort;
             5     CString sSaveDir = pPara->sSaveDir;
             6     delete pPara;
             7     pPara = NULL;
             8 
             9     SocketThreadInit();
            10     try
            11     {
            12         CSocket liseningSocket;
            13         if ( !liseningSocket.Create(nListenPort) )
            14         {
            15             LOG("創建TCP端口失敗, 可能是端口%d被占用", nListenPort);
            16             return 1;
            17         }
            18 
            19         if ( !liseningSocket.Listen(5) )
            20         {
            21             LOG("啟動Socket監聽失敗");
            22             return 1;
            23         }
            24 
            25         while(true)
            26         {
            27             CSocket clientSocket;
            28             if ( liseningSocket.Accept(clientSocket) )
            29             {
            30                 FileTransferThreadStruct *pFileTrans = new FileTransferThreadStruct;
            31                 pFileTrans->hSOCKET  = clientSocket.Detach();
            32                 pFileTrans->sSaveDir = sSaveDir;
            33 
            34                 AfxBeginThread(FileTransferThread2, (LPVOID)pFileTrans);
            35             }
            36             else
            37             {
            38                 liseningSocket.Close();
            39                 break;
            40             }
            41         }
            42     }
            43     catch()
            44     {
            45         LOG("監控Socket線程收到異常, 監聽結束");
            46         return 0;
            47     }
            48     return 0;
            49 }
            50 
            51 
            52 UINT CSocketFun::FileTransferThread2(LPVOID lparam)
            53 {
            54     FileTransferThreadStruct *pPara = (FileTransferThreadStruct*)lparam;
            55     SOCKET  sock     = pPara->hSOCKET;
            56     CString sSaveDir = pPara->sSaveDir;
            57     delete pPara;
            58     pPara = NULL;
            59 
            60     SocketThreadInit();
            61 
            62     CSocket aSocket;
            63     aSocket.Attach(sock);
            64 
            65     char buffer[SERVER_SOCKET_BUFFERSIZE] = {'\0'};
            66     int nLen = aSocket.Receive(buffer, MAX_PATH);
            67 }

            調用線程.cpp文件中。
            1 ListeningThreadStruct *pPara = new ListeningThreadStruct;
            2 pPara->sSaveDir    = m_sSaveDir;
            3 pPara->nListenPort = m_nListenPort;
            4 
            5 CWinThread *pThread = AfxBeginThread(ListeningThreadProc, (LPVOID)pPara);

            客戶端:

            示例代碼:
             1 #define OutStr(x, )    \
             2 {\
             3     CString sMsg; \
             4     sMsg.Format(x, __VA_ARGS__); \
             5     if (sMsg.GetLength() < (int)nErrBufLen) \
             6     strcpy_s(pErrorBuf, nErrBufLen, sMsg); \
             7 else \
             8     strcpy_s(pErrorBuf, nErrBufLen, "緩沖區大小不足"); \
             9 }
            10 
            11 
            12 AFX_MANAGE_STATE(AfxGetStaticModuleState()); 
            13 
            14     if (!AfxSocketInit())
            15     {
            16         return 1 ;
            17     }
            18 
            19     SocketThreadInit();
            20 
            21     CSocket aSocket;
            22     if (!aSocket.Create())
            23     {
            24         OutStr("創建socket失敗");
            25         return 1;
            26     }
            27 
            28     if (!aSocket.Connect(sServerIP, nPort))
            29     {
            30         OutStr("連接服務器失敗IP %s 端口 %d", sServerIP, nPort);
            31         return 1;
            32     }
            33 
            34     CFile file;
            35     if (!file.Open(sFile, CFile::modeRead))
            36     {
            37         OutStr("發送文件時, 文件%s打開失敗", sFile);
            38         return 1;
            39     }
            40 
            41     // 1. send file name
            42     char fileName[MAX_PATH] = {'\0'};
            43     strcpy_s( fileName, MAX_PATH, CCommonFun::GetFileFullName(sFile) );
            44     if ( SOCKET_ERROR == aSocket.Send(fileName, MAX_PATH) )
            45     {
            46         OutStr("文件名通過socket發送失敗");
            47         return 1;
            48     }
            49 
            50     // 2. send file size
            51     ULONGLONG ulFileLen = file.GetLength();
            52     if (SOCKET_ERROR == aSocket.Send(&ulFileLen, sizeof(ULONGLONG) ) )
            53     {
            54         OutStr("文件長度通過socket發送失敗");
            55         return 1;
            56     }
            57 
            58     try
            59     {
            60         char buffer[CLIENT_SOCKET_BUFFERSIZE] = {'\0'};
            61         UINT nTotalLen = 0;
            62         UINT nLen = 0;
            63         while ((nLen = file.Read(buffer, CLIENT_SOCKET_BUFFERSIZE)) > 0)
            64         {
            65             if (SOCKET_ERROR == aSocket.Send(buffer, nLen))
            66             {
            67                 OutStr("文件數據通過socket發送失敗, 已發送%d", nTotalLen);
            68                 return 1;
            69             }
            70 
            71             nTotalLen += nLen;
            72         }            
            73     }
            74     catch ()
            75     {
            76         OutStr("發送文件數據時收到一個異常, 發送失敗");
            77         return 1;
            78     }
            79 
            80 #define SOCKET_OK_BUFFERSIZE 1024
            81     char szOK[SOCKET_OK_BUFFERSIZE] = {'\0'};
            82     int nLen = aSocket.Receive(szOK, SOCKET_OK_BUFFERSIZE);
            83     if (CString(szOK) != "ok")
            84     {
            85         OutStr("未收到合法的服務器回文, 發送失敗");
            86         return 1;
            87     }

            posted on 2012-04-26 13:58 王海光 閱讀(1864) 評論(0)  編輯 收藏 引用 所屬分類: MFC
            久久人人爽人人爽人人av东京热| 国产精品一区二区久久不卡| 2022年国产精品久久久久| 久久综合色老色| 精品久久久久久无码人妻蜜桃| 2020久久精品国产免费| 久久精品人人做人人妻人人玩| 中文字幕乱码久久午夜| 伊人久久大香线蕉综合影院首页| 久久中文字幕人妻丝袜| 伊人久久大香线蕉av不变影院| 亚洲欧美日韩中文久久| 亚洲精品乱码久久久久久| 精品国产乱码久久久久久郑州公司| 久久综合给合久久狠狠狠97色| 99久久人妻无码精品系列| 久久国产精品成人免费 | 久久精品国产亚洲av麻豆色欲 | 日韩亚洲国产综合久久久| 久久久久久国产a免费观看黄色大片 | 伊人久久大香线蕉av不变影院| 日日躁夜夜躁狠狠久久AV| 久久久久久久97| 久久996热精品xxxx| 国内高清久久久久久| 久久久久亚洲AV片无码下载蜜桃 | 久久综合欧美成人| 久久久久人妻精品一区三寸蜜桃 | 无码国内精品久久人妻| 久久精品人成免费| 久久人人爽人人爽人人片AV麻豆| 精品综合久久久久久98| 大香网伊人久久综合网2020| 思思久久99热只有频精品66| 97久久久精品综合88久久| 久久亚洲视频| 香蕉久久一区二区不卡无毒影院| 亚洲国产成人精品无码久久久久久综合| A级毛片无码久久精品免费| 国产成人精品久久综合| 日产精品久久久久久久性色|