tftp的c语言实现,GitHub - ideawu/tftpx: TFTP server and client implementation in C
TFTP的擴展和實現
用C語言開發的在Linux平臺上的TFTP(RFC1350)服務器端和客戶端. 支持目錄列表, 可變塊大小(RFC2348). 傳輸模式只支持二進制模式.
停止等待(Stop and Wait)和自動重傳(ARQ)機制作為數據傳輸的基本機制, 是網絡編程必須要掌握的技能. TFTP 協議使用基于UDP的停止等待和超時重傳機制來實現文件的可靠傳輸.
在查看 tftpx 的源碼之前, 你最好先閱讀 W.Richard.Stevens 的 TCP/IP Illustrated Volume 1: The Protocols(TCP/IP詳解 卷1:協議).
tftpx 使用這樣的代碼來實現停止等待機制:
int send_packet(int sock, struct tftpx_packet *packet, int size){
struct tftpx_packet rcv_packet;
int time_wait_ack = 0;
int rxmt = 0;
int r_size = 0;
for(rxmt = 0; rxmt < PKT_MAX_RXMT; rxmt ++){
printf("Send block=%d\n", ntohs(packet->block));
if(send(sock, packet, size, 0) != size){
return -1;
}
for(time_wait_ack = 0; time_wait_ack < PKT_RCV_TIMEOUT; time_wait_ack += 20000){
usleep(20000);
// Try receive(Nonblock receive).
r_size = recv(sock, &rcv_packet, sizeof(struct tftpx_packet), MSG_DONTWAIT);
if(r_size >= 4 && rcv_packet.cmd == htons(CMD_ACK) && rcv_packet.block == packet->block){
//printf("ACK: block=%d\n", ntohs(rcv_packet.block));
// Valid ACK
break;
}
}
if(time_wait_ack < PKT_RCV_TIMEOUT){
break;
}else{
// Retransmission.
continue;
}
}
if(rxmt == PKT_MAX_RXMT){
// send timeout
printf("Sent packet exceeded PKT_MAX_RXMT.\n");
return -1;
}
return size;
}
總結
以上是生活随笔為你收集整理的tftp的c语言实现,GitHub - ideawu/tftpx: TFTP server and client implementation in C的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 大学不挂科c语言题库及答案,C语言期末总
- 下一篇: picf509c语言程序,樊媛媛c语言程