開始學習(算是複習)網絡編程了,第一個就是局域網的netbios協議編程。ios
首先了解一下什麼是netbios:IBM公司爲PC-Network開發的一套網絡標準。,NetBIOS最普遍的應用之一就是對NetBIOS用戶擴展接口(NetBEUI,NetBIOS Extend User Interface)協議的使用。處在表示層與會話層之間,處於參考模型的高層。編程
優勢:短小精練; 良好的網絡通訊性能; 適合於適時性較高的小型LAN網絡環境;windows
缺點:是一種不可路由的協議;數據包沒法跨網段傳輸。api
NetBIOS程序的工做過程:網絡
首先,網絡通訊程序經過名字的標識區別於其餘程序,並將名字註冊到LANA中,得到合法的網絡身份。app
以後,網絡通訊程序可使用NetBIOS的數據報或會話服務與駐留在相同或不一樣主機中的其餘應用程序進行通訊。通訊過程當中,用戶還可使用通常命令服務對適配器進行管理和監測。異步
最後,在通訊結束後,通訊程序須要刪除已註冊的名字並釋放所佔用的網絡資源。ide
編程講解:函數
在Win32環境下,使用VS2012進行NetBIOS程序開發時, 須要用到nb30.h文件和netapi32.lib靜態連接庫。前者定義了NetBIOS的全部函數聲明和常數定義,後者定義了NetBIOS應用。Ncb的結構在nb30.h文件中定義。Ncb結構的定義:Ncb有64個字符,分爲14個域(或稱爲字段)和一個10字節的保留域。各字段這裏就不詳細了,另一個博客有講解。post
編寫NetBios命令函數的步驟:
1. 定義函數原型。
2. 申明NCB結構變量。
3. 對該變量全部域清零。
4. 根據命令填寫相關域。
5. 調用NetBios函數提交NCB結構。
6. 判斷NetBios函數返回值,做出相應處理。
7. 從NCB中獲取輸出域。(根據具體命令)
簡單的基於NetBios的對話編程,實現了創建會話過程,客戶端向服務端發送數據,服務端接受數據並回複數據,客戶端成功接受並沒有限遞歸(固然程序能夠本身修改)。win32,vs2012,C++平臺參考代碼以下:
服務端代碼參考:
1 //服務端參考代碼: 2 #include <windows.h> 3 #include <stdio.h> 4 #include <nb30.h> 5 #include "NetBioscmd.h" 6 #define MAX_SESSIONS 254 7 #define MAX_NAMES 254 8 #define MAX_BUFFER 1024 9 #define SERVER_NAME "server" 10 // 11 //Thread to give a simple service to client 12 // 13 DWORD WINAPI ServerThread(PVOID lpParam) 14 { 15 PNCB pncb =(PNCB)lpParam; 16 NCB ncb; 17 char buff[MAX_BUFFER], 18 Clientname[NCBNAMSZ+1]; 19 DWORD Bufferlen,retval =NRC_GOODRET; 20 FormatNetbiosName((char *)&pncb->ncb_callname,Clientname); 21 printf("a connect come\n"); 22 ZeroMemory(buff,MAX_BUFFER); 23 Bufferlen =MAX_BUFFER; 24 25 while (true) 26 { 27 retval =Recv(pncb->ncb_lana_num,pncb->ncb_lsn,buff,Bufferlen); 28 if(retval!=NRC_GOODRET) 29 return pncb->ncb_retcode; 30 printf("Massage from[%s]:%s\n",Clientname,buff); 31 ZeroMemory(buff,MAX_BUFFER); 32 Bufferlen =MAX_BUFFER; 33 strcpy(buff,"welcome you join the NetBIOS club."); 34 retval =Send(pncb->ncb_lana_num,pncb->ncb_lsn,buff,Bufferlen); 35 if(retval!=NRC_GOODRET) 36 return pncb->ncb_retcode; 37 } 38 39 if(retval!=NRC_SCLOSED) 40 { 41 ZeroMemory(&ncb,sizeof(NCB)); 42 ncb.ncb_command =NCBHANGUP; 43 ncb.ncb_lsn =pncb->ncb_lsn; 44 ncb.ncb_lana_num =pncb->ncb_lana_num; 45 if(Netbios(&ncb)!=NRC_GOODRET) 46 { 47 GlobalFree(pncb); 48 retval =ncb.ncb_retcode; 49 } 50 } 51 GlobalFree(pncb); 52 return NRC_GOODRET; 53 } 54 // 55 //Callback function to give a simple service to client, you can use it as another sever model 56 // 57 void CALLBACK listencallback(PNCB pncb) 58 { 59 // 60 //you also can write down code here to communicate to a client 61 // 62 } 63 //main function 64 int main(int argc, char* argv[]) 65 { 66 HANDLE hEvent[64],hThread; 67 NCB *pncb, 68 *workpncb; 69 DWORD ThreadId, 70 dwIndex; 71 UCHAR dwNum = ' '; 72 LANA_ENUM lenum; 73 int i; 74 if(LanaEnum(&lenum)!=NRC_GOODRET) 75 { 76 return 1; 77 } 78 if(ResetAll(&lenum,(UCHAR)MAX_SESSIONS,(UCHAR)MAX_NAMES,false)!=NRC_GOODRET) 79 return 1; 80 pncb = (NCB*)GlobalAlloc(GMEM_FIXED|GMEM_ZEROINIT,sizeof(NCB)*lenum.length); 81 for(i=0;i<lenum.length;i++) 82 if((AddName((int)lenum.lana[i],SERVER_NAME,&dwNum))==NRC_GOODRET) 83 {printf("add name(%s) to lana[%d]\n",SERVER_NAME,lenum.lana[i]); 84 //printf("name(%s) have the name_num (%d)\n",SERVER_NAME,dwNum); 85 } 86 for(i=0;i<lenum.length;i++) 87 { 88 hEvent[i]=CreateEvent(0,TRUE,FALSE,0); 89 if(Listen(&pncb[i],lenum.lana[i],SERVER_NAME,hEvent[i])==NRC_GOODRET) 90 printf("attempt to listen to lana[%d] succeed!\n",lenum.lana[i]); 91 } 92 printf("Server setup has been finished,now server begin to listen.\n"); 93 while(true) 94 { 95 dwIndex=WaitForMultipleObjects(lenum.length,hEvent,FALSE,INFINITE); 96 if(dwIndex==WAIT_FAILED) 97 { 98 printf("WaitForMultipleObjects ERROR:%0xh\n",GetLastError()); 99 break; 100 } 101 else 102 { 103 for(int i=0;i<lenum.length;i++) 104 { 105 if(pncb[i].ncb_cmd_cplt!=NRC_PENDING) 106 { 107 workpncb = (NCB *)GlobalAlloc(GMEM_FIXED,sizeof(NCB)); 108 memcpy(workpncb,&pncb[i],sizeof(NCB)); 109 workpncb->ncb_event = 0; 110 hThread=CreateThread(NULL,0,ServerThread,(LPVOID)workpncb,0,&ThreadId); 111 CloseHandle(hThread); 112 ResetEvent(hEvent[i]); 113 Listen(&pncb[i],lenum.lana[i],SERVER_NAME,hEvent[i]); 114 } 115 else 116 continue; 117 } 118 } 119 } 120 for(i=0;i<lenum.lana[i];i++) 121 { 122 DelName(lenum.lana[i],SERVER_NAME); 123 CloseHandle(hEvent[i]); 124 } 125 GlobalFree(hEvent); 126 GlobalFree(pncb); 127 return 0; 128 }
客戶端代碼參考:
1 //客戶端參考代碼: 2 // client.cpp : Defines the entry point for the console application. 3 // 4 5 #include <windows.h> 6 #include <stdio.h> 7 #include <nb30.h> 8 #include <winbase.h> 9 #include "NetBioscmd.h" 10 #define MAX_SESSIONS 254 11 #define MAX_NAMES 254 12 #define MAX_BUFFER 1024 13 #define MAX_DATAGRAM_SIZE 512 14 #define CLIENT_NAME "client" 15 #define SERVER_NAME "server" 16 //main fuction 17 int main(int argc, char* argv[]) 18 { 19 HANDLE *hEvent; 20 NCB *pncb; 21 DWORD dwRet, 22 Bufferlen,dwIndex; 23 UCHAR *dwNum = NULL; 24 char Buff[MAX_BUFFER], 25 Servername[NCBNAMSZ+1]; 26 LANA_ENUM lenum; 27 int i; 28 if(LanaEnum(&lenum)!=NRC_GOODRET) 29 return 1; 30 if(ResetAll(&lenum,(UCHAR)MAX_SESSIONS,(UCHAR)MAX_NAMES,false)!=NRC_GOODRET) 31 return 1; 32 hEvent = (HANDLE*)GlobalAlloc(GMEM_FIXED,sizeof(HANDLE)*lenum.length); //分配內存 33 pncb = (NCB*)GlobalAlloc(GMEM_FIXED|GMEM_ZEROINIT,sizeof(NCB)*lenum.length); 34 dwNum = (UCHAR*)GlobalAlloc(GMEM_FIXED|GMEM_ZEROINIT,sizeof(UCHAR)*lenum.length); 35 for(i=0;i<lenum.length;i++) //增長名字 36 if((AddName((int)lenum.lana[i],CLIENT_NAME,(UCHAR*)&dwNum[i]))==NRC_GOODRET) 37 { printf("add name(%s) to lana[%d]\n",CLIENT_NAME,lenum.lana[i]); 38 //printf("name(%s) have the name_num (%d)\n",CLIENT_NAME,dwNum[i]); 39 } 40 for(i=0;i<lenum.length;i++)// 鏈接 41 { 42 hEvent[i]=CreateEvent(0,TRUE,FALSE,0); 43 if((Connect(&pncb[i],lenum.lana[i],SERVER_NAME,CLIENT_NAME,hEvent[i]))==NRC_GOODRET) 44 printf("attempt to connect to lana[%d] succeed!\n",lenum.lana[i]); 45 } 46 47 dwIndex = WaitForMultipleObjects(lenum.length,hEvent,FALSE,INFINITE); 48 49 if(dwIndex == WAIT_FAILED) 50 printf("ERROR:WaitForMultipleObjects:%0xh\n",GetLastError()); 51 else 52 { 53 for(int i=0;i<lenum.length;i++) 54 { 55 if(i!=(int)dwIndex) 56 { 57 if(pncb[i].ncb_cmd_cplt==NRC_PENDING) //異步 58 Cancel(&pncb[i]); 59 else 60 Hangup(pncb[i].ncb_lana_num,pncb[i].ncb_lsn); 61 } 62 } 63 //printf("%i",(int)pncb[dwIndex].ncb_lana_num); 64 printf("a connect on[LANA %i] has been built!\n",(int)pncb[dwIndex].ncb_lana_num); 65 ZeroMemory(Buff,MAX_BUFFER); 66 Bufferlen = MAX_BUFFER; 67 while (TRUE) 68 { 69 strcpy(Buff,"I want to register to you."); 70 dwRet = Send(pncb[dwIndex].ncb_lana_num,pncb[dwIndex].ncb_lsn,Buff,Bufferlen); 71 if(dwRet!=NRC_GOODRET) 72 return pncb[dwIndex].ncb_retcode; 73 ZeroMemory(Buff,MAX_BUFFER); 74 dwRet=Recv(pncb[dwIndex].ncb_lana_num,pncb[dwIndex].ncb_lsn,Buff,Bufferlen); 75 if(dwRet!=NRC_GOODRET) 76 return pncb[dwIndex].ncb_retcode; 77 FormatNetbiosName((char *)&pncb->ncb_callname,Servername); 78 printf("Massage from[%s]:%s\n",Servername,Buff); 79 } 80 81 Hangup(pncb[dwIndex].ncb_lana_num,pncb[dwIndex].ncb_lsn); 82 } 83 84 85 for(i=0;i<lenum.length;i++) 86 { 87 DelName(lenum.lana[i],CLIENT_NAME); 88 CloseHandle(hEvent[i]); 89 } 90 GlobalFree(hEvent); 91 GlobalFree(pncb); 92 return 0; 93 }
其中須要一個頭文件NetBIOScmd.h部分參考代碼:
1 //NetBIOScmd.h 部分參考代碼: 2 // 3 //Get the status of local or remote adapter 4 // 5 #define MAX_DATAGRAM_SIZE 512 6 int Astatus(ADAPTER_STATUS *astat,int lana,char *name) 7 { 8 NCB ncb; 9 ZeroMemory(&ncb,sizeof(NCB)); 10 ncb.ncb_command = NCBASTAT; 11 ncb.ncb_buffer = (PUCHAR)astat; 12 ncb.ncb_length = sizeof(ADAPTER_STATUS); 13 memset(&ncb.ncb_callname,' ',NCBNAMSZ); 14 strncpy((char *)&ncb.ncb_callname,name,strlen(name)); 15 ncb.ncb_lana_num = lana; 16 if(Netbios(&ncb)!=NRC_GOODRET) 17 { 18 printf("Netbios NCBASTAT ERROR:%0xh\n",ncb.ncb_retcode); 19 return ncb.ncb_retcode; 20 } 21 return NRC_GOODRET; 22 } 23 // 24 //Get the machine's LANA NUM 25 // 26 int LanaEnum(LANA_ENUM *lenum) 27 { 28 NCB ncb; 29 ZeroMemory(&ncb,sizeof(NCB)); 30 ncb.ncb_command = NCBENUM; 31 ncb.ncb_buffer = (PUCHAR)lenum; 32 ncb.ncb_length = sizeof(LANA_ENUM); 33 if(Netbios(&ncb)!=NRC_GOODRET) 34 { 35 printf("Netbios NEBENUM ERROR:%0xh\n",ncb.ncb_retcode); 36 return ncb.ncb_retcode; 37 } 38 return NRC_GOODRET; 39 } 40 // 41 //Reset All LANA NUM 42 // 43 int ResetAll(LANA_ENUM *lenum,UCHAR ucMaxSession,UCHAR unMaxName,BOOL bFirstname) 44 { 45 NCB ncb; 46 ZeroMemory(&ncb,sizeof(NCB)); 47 ncb.ncb_command = NCBRESET; 48 ncb.ncb_callname[0] = ucMaxSession; 49 ncb.ncb_callname[1] = unMaxName; 50 ncb.ncb_callname[2] = (UCHAR)bFirstname; 51 for(int i=0;i<lenum->length;i++) 52 { 53 ncb.ncb_lana_num = lenum->lana[i]; 54 if(Netbios(&ncb)!=NRC_GOODRET) 55 { 56 printf("Netbios NCBRESET[%d]ERROR:%0xh\n",ncb.ncb_lana_num,ncb.ncb_retcode); 57 return ncb.ncb_retcode; 58 } 59 } 60 return NRC_GOODRET; 61 } 62 // 63 //Add name of program 64 // 65 int AddName(int lana,char *name,UCHAR *num) 66 { 67 NCB ncb; 68 ZeroMemory(&ncb,sizeof(NCB)); 69 ncb.ncb_command = NCBADDNAME; 70 ncb.ncb_lana_num = lana; 71 memset(ncb.ncb_name,' ',NCBNAMSZ);//add by jinhua 72 strncpy((char *)ncb.ncb_name,name,strlen(name)); 73 if(Netbios(&ncb)!=NRC_GOODRET) 74 { 75 printf("Netbios NCBADDNAME[lana=%d;name=%s]ERROR:%0xh\n",lana,name,ncb.ncb_retcode); 76 return ncb.ncb_retcode; 77 } 78 *num = ncb.ncb_num; 79 return NRC_GOODRET; 80 } 81 // 82 //Cancel NetBios Command 83 // 84 int Cancel(PNCB pncb) 85 { 86 NCB ncb; 87 ZeroMemory(&ncb,sizeof(NCB)); 88 ncb.ncb_command = NCBCANCEL; 89 ncb.ncb_buffer = (PUCHAR)pncb; 90 ncb.ncb_lana_num = pncb->ncb_lana_num; 91 if(Netbios(&ncb)!=NRC_GOODRET) 92 { 93 printf("Netbios NCBCANCEL ERROR:%0xh\n",ncb.ncb_retcode); 94 return ncb.ncb_retcode; 95 } 96 return NRC_GOODRET; 97 } 98 // 99 //Hangup Command 100 // 101 int Hangup(int lana,int lsn) 102 { 103 NCB ncb; 104 int retcode; 105 ZeroMemory(&ncb,sizeof(NCB)); 106 ncb.ncb_command = NCBHANGUP; 107 ncb.ncb_lsn = lsn; 108 ncb.ncb_lana_num = lana; 109 retcode = Netbios(&ncb); 110 return retcode; 111 } 112 // 113 //Delete Name Command 114 // 115 int DelName(int lana,char *name) 116 { 117 NCB ncb; 118 ZeroMemory(&ncb,sizeof(NCB)); 119 ncb.ncb_command = NCBDELNAME; 120 ncb.ncb_lana_num = lana; 121 //memset(ncb.ncb_name,' ',strlen(name)); 122 memset(ncb.ncb_name,' ',NCBNAMSZ);//add by jinhua 123 strncpy((char *)ncb.ncb_name,name,strlen(name)); 124 if(Netbios(&ncb) != NRC_GOODRET) 125 { 126 printf("Netbios NCBDELNAME [lana=%d;name=%s] ERROR:%0xh\n",lana,name,ncb.ncb_retcode); 127 return ncb.ncb_retcode; 128 } 129 return NRC_GOODRET; 130 } 131 // 132 //Add the group name to LANA number 133 //Retrun the name number for the registered name. 134 // 135 int AddGroupName(int lana,char *name,UCHAR *num) 136 { 137 NCB ncb; 138 ZeroMemory(&ncb,sizeof(NCB)); 139 ncb.ncb_command = NCBADDGRNAME; 140 ncb.ncb_lana_num = lana; 141 memset(ncb.ncb_name,' ',NCBNAMSZ); 142 strncpy((char *)ncb.ncb_name,name,strlen(name)); 143 if(Netbios(&ncb)!=NRC_GOODRET) 144 { 145 printf("Netbios NCBADDGRPNAME[lana=%d;name=%s] ERROR:%0xh\n",lana,name,ncb.ncb_retcode); 146 return ncb.ncb_retcode; 147 } 148 *num = ncb.ncb_num; 149 return NRC_GOODRET; 150 } 151 // 152 //function to realize NCBRECV 153 // 154 int Recv(int lana,int lsn,char *buffer,DWORD bufferlen) 155 { 156 NCB ncb; 157 ZeroMemory(&ncb,sizeof(NCB)); 158 ncb.ncb_command =NCBRECV; 159 ncb.ncb_buffer =(PUCHAR)buffer; 160 ncb.ncb_length =(unsigned short)bufferlen; 161 ncb.ncb_lana_num =lana; 162 ncb.ncb_lsn =lsn; 163 if(Netbios(&ncb)!=NRC_GOODRET) 164 { 165 bufferlen = -1; 166 printf("Netbios NCBRECV ERROR:%0xh.\n",ncb.ncb_retcode); 167 return ncb.ncb_retcode; 168 } 169 bufferlen = ncb.ncb_length; 170 return NRC_GOODRET; 171 } 172 // 173 //function to realize NCBSEND 174 // 175 int Send(int lana,int lsn,char *data,DWORD len) 176 { 177 NCB ncb; 178 int retcode; 179 ZeroMemory(&ncb,sizeof(NCB)); 180 ncb.ncb_command =NCBSEND; 181 ncb.ncb_buffer =(PUCHAR)data; 182 ncb.ncb_length =(unsigned short)len; 183 ncb.ncb_lsn =lsn; 184 ncb.ncb_lana_num =lana; 185 retcode =Netbios(&ncb); 186 return retcode; 187 } 188 // 189 //covert the NetBIOS name from unprintable to printable 190 // 191 int FormatNetbiosName(char *nbname,char *outname) 192 { 193 int i; 194 strncpy(outname,nbname,NCBNAMSZ); 195 outname[NCBNAMSZ-1] = '\0'; 196 for(i=0;i<NCBNAMSZ-1;i++) 197 { 198 if(!((outname[i]>=32)&&(outname[i]<=126))) 199 outname[i] = '.'; 200 } 201 return NRC_GOODRET; 202 } 203 // 204 //Send a broadcast datagram on the specified LANA number 205 // 206 int DatagramSendBC(int lana,int num,char *buffer,int buflen) 207 { 208 NCB ncb; 209 ZeroMemory(&ncb,sizeof(NCB)); 210 ncb.ncb_command = NCBDGSENDBC; 211 ncb.ncb_lana_num = lana; 212 ncb.ncb_num = (UCHAR)num; 213 ncb.ncb_buffer = (PUCHAR)(buffer); 214 ncb.ncb_length = buflen; 215 if(Netbios(&ncb)!=NRC_GOODRET) 216 { 217 printf("Netbios NCBDGSENDBC ERROR:%0xh\n",ncb.ncb_retcode); 218 return ncb.ncb_retcode; 219 } 220 return NRC_GOODRET; 221 } 222 // 223 //receive a broadcast datagram on the specified LANA number from the registered name 224 // 225 int DatagramRecvBC(PNCB pncb,int lana,int num,char *buffer,int buflen,HANDLE hEvent) 226 { 227 ZeroMemory(pncb,sizeof(NCB)); 228 ZeroMemory(buffer,sizeof(MAX_DATAGRAM_SIZE)); 229 pncb->ncb_command = NCBDGRECVBC|ASYNCH; 230 pncb->ncb_lana_num = lana; 231 pncb->ncb_buffer = (PUCHAR)(buffer); 232 pncb->ncb_length = buflen; 233 pncb->ncb_event = hEvent; 234 if(Netbios(pncb)!=NRC_GOODRET) 235 { 236 printf("Netbios NCBDGRECVBC ERROR:%0xh\n",pncb->ncb_retcode); 237 return pncb->ncb_retcode; 238 } 239 return NRC_GOODRET; 240 } 241 // 242 //Send a directed datagram on the specified LANA number 243 // 244 int DatagramSend(int lana,int num,char *buffer,int buflen,char *Destname) 245 { 246 NCB ncb; 247 ZeroMemory(&ncb,sizeof(NCB)); 248 ncb.ncb_command =NCBDGSEND; 249 ncb.ncb_lana_num =lana; 250 ncb.ncb_num =(UCHAR)num; 251 ncb.ncb_buffer =(PUCHAR)buffer; 252 ncb.ncb_length =buflen; 253 memset(ncb.ncb_name,' ',NCBNAMSZ); 254 strncpy((char *)ncb.ncb_callname,Destname,strlen(Destname)); 255 if(Netbios(&ncb)!=NRC_GOODRET) 256 { 257 printf("Netbios NCBDGSEND ERROR:%0xh\n",ncb.ncb_retcode); 258 return ncb.ncb_retcode; 259 } 260 return NRC_GOODRET; 261 } 262 // 263 //Recieve a directed datagram on the specified LANA number from registered name 264 // 265 int DatagramRecv(PNCB pncb,int lana,int num,char *buffer,int buflen,HANDLE hEvent) 266 { 267 ZeroMemory(pncb,sizeof(NCB)); 268 ZeroMemory(buffer,sizeof(MAX_DATAGRAM_SIZE)); 269 pncb->ncb_command =NCBDGRECV|ASYNCH; 270 pncb->ncb_lana_num =lana; 271 pncb->ncb_num =(UCHAR)num; 272 pncb->ncb_buffer =(PUCHAR)buffer; 273 pncb->ncb_length =buflen; 274 pncb->ncb_event =hEvent; 275 if(Netbios(pncb)!=NRC_GOODRET) 276 { 277 printf("Netbios NCBDGRECV ERROR:%0xh\n",pncb->ncb_retcode); 278 return pncb->ncb_retcode; 279 } 280 return NRC_GOODRET; 281 } 282 // 283 //function to realize NCBLISTEN 284 // 285 int Listen(PNCB pncb,int lana,char *server,HANDLE hEvent) 286 { 287 pncb->ncb_command = NCBLISTEN|ASYNCH; 288 pncb->ncb_lana_num = lana; 289 memset(&pncb->ncb_name,' ',NCBNAMSZ); 290 strncpy((char *)&pncb->ncb_name,server,strlen(server)); 291 memset(&pncb->ncb_callname,' ',NCBNAMSZ); 292 pncb->ncb_callname[0] = '*'; 293 pncb->ncb_event = hEvent; 294 //you also can use callback function to providw service to client 295 //pncb->ncb_post =listencallback; 296 if(Netbios(pncb)!=NRC_GOODRET) 297 { 298 printf("Netbios NCBLISTEN ERROR:%0xh.\n",pncb->ncb_retcode); 299 return pncb->ncb_retcode; 300 } 301 return NRC_GOODRET; 302 } 303 // 304 //fuction to realize NCBCALL 305 // 306 int Connect(PNCB pncb,int lana,char *server,char *client,HANDLE hEvent) 307 { 308 pncb->ncb_command =NCBCALL|ASYNCH; 309 pncb->ncb_lana_num =lana; 310 memset(&pncb->ncb_name,' ',NCBNAMSZ); 311 strncpy((char *)&pncb->ncb_name,client,strlen(client)); 312 memset(&pncb->ncb_callname,' ',NCBNAMSZ); 313 strncpy((char *)&pncb->ncb_callname,server,strlen(server)); 314 pncb->ncb_event =hEvent; 315 if(Netbios(pncb)!=NRC_GOODRET) 316 { 317 printf("ERROR:Netbios:NCBCONNECT.%0xh\n",pncb->ncb_retcode); 318 return pncb->ncb_retcode; 319 } 320 return NRC_GOODRET; 321 }
這兩天看的netbios,簡單整理了一下,分享給園友,有問題請指正,謝謝。