亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? tftp_server_linux.c

?? linux下的tftp源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
            exit(1);
        }
        if (*filename != '/') {
            if (debug)
                syslog(LOG_ERR,
                       "Filename has to be absolute: %s\n",
                       filename);
            nak(EACCESS);
            exit(1);
        }
        filename = strcat(strcpy(cp, rootdir), filename);
    }
   
    ecode = (*pf->f_validate)(filename, tp->th_opcode);
    if (ecode) {
        nak(ecode, ERROR);
        exit(1);
    }
    isopts = ap != (ackbuf+2);
    (tp->th_opcode == WRQ ? *pf->f_recv : *pf->f_send)
        (pf, isopts ? ackbuf : NULL, isopts ? ap-ackbuf : 0);
    exit(0);
}


FILE *file;

/*
* Validate file access.  Since we
* have no uid or gid, for now require
* file to exist and be publicly
* readable/writable.
* Note also, full path name must be
* given as we have no login directory.
*/
validate_access(filename, mode)
    char *filename;
    int mode;
{
    struct stat stbuf;
    int    fd;
    char    *cp;

    isfilter = 0;
    if (mode == RRQ) {
        struct filters *fp = filters;
        for (; fp; fp = fp->next) {
            if (!strcmp(fp->fname,
                    filename +
                    (rootdir ? strlen(rootdir) : 0))) {
                if (debug)
                    syslog(LOG_INFO, "Opening input "
                           "filter: %s\n", filename);
                if ((file = popen(filename, "r")) == NULL) {
                    syslog(LOG_ERR, "Failed to open input "
                           "filter\n");
                    return (EACCESS); }
                fd = fileno(file);
                isfilter = 1;
                return (0);
            }
        }
    }
                       
    if (*filename != '/') {
        if (debug)
            syslog(LOG_ERR, "Filename has to be absolute: %s\n",
                   filename);
        return (EACCESS);
    }
    for (cp = filename; *cp; cp++)
        if (*cp == '~' || *cp == '$' ||
            (*cp == '/' && cp[1] == '.' && cp[2] == '.')) {
            if (debug)
                syslog(LOG_ERR, "Illegal filename: %s\n",
                       filename);
            return (EACCESS);
        }
    if (debug)
        syslog(LOG_INFO, "Validating \"%s\" for %sing\n",
               filename, mode == RRQ ? "read" : "writ");
    if (stat(filename, &stbuf) < 0)
        return (errno == ENOENT ? ENOTFOUND : EACCESS);
    if (mode == RRQ) {
        if ((stbuf.st_mode&(S_IREAD >> 6)) == 0)
            return (EACCESS);
    } else {
        if ((stbuf.st_mode&(S_IWRITE >> 6)) == 0)
            return (EACCESS);
    }
    fd = open(filename, mode == RRQ ? 0 : 1);
    if (fd < 0)
        return (errno + 100);
    file = fdopen(fd, (mode == RRQ)? "r":"w");
    if (file == NULL) {
        return errno+100;
    }
    return (0);
}

int    timeout;
jmp_buf    timeoutbuf;

void timer(int sig)
{

    timeout += rexmtval;
    if (timeout >= maxtimeout) {
        if (debug)
            syslog(LOG_WARNING, "Timeout!\n");
        exit(1);
    }
    longjmp(timeoutbuf, 1);
}

/*
* Send the requested file.
*/
sendfile(pf, oap, oacklen)
    struct formats *pf;
    struct tftphdr *oap;
    int oacklen;
{
    struct tftphdr *dp, *r_init();
    register struct tftphdr *ap;    /* ack packet */
    register int size, n;
    u_short block = 1;

    signal(SIGALRM, timer);

    ap = (struct tftphdr *)ackbuf;

    if (oap) {
        timeout = 0;
        (void) setjmp(timeoutbuf);
    oack:
        if (send(peer, oap, oacklen, 0) != oacklen) {
            syslog(LOG_ERR, "tftpd: write: %m\n");
            goto abort;
        }
        for ( ; ; ) {
            alarm(rexmtval);
            n = recv(peer, ackbuf, sizeof (ackbuf), 0);
            alarm(0);
            if (n < 0) {
                syslog(LOG_ERR, "tftpd: read: %m\n");
                goto abort;
            }
            ap->th_opcode = ntohs((u_short)ap->th_opcode);
            ap->th_block = ntohs(ap->th_block);
           
            if (ap->th_opcode == ERROR) {
                if (debug)
                    syslog(LOG_ERR, "Client does not "
                           "accept options\n");
                goto abort; }
           
            if (ap->th_opcode == ACK) {
                if (ap->th_block == 0) {
                    if (debug)
                        syslog(LOG_DEBUG,
                               "RFC1782 option "
                               "negotiation "
                               "succeeded\n");
                    break;
                }
                /* Re-synchronize with the other side */
                (void) synchnet(peer);
                goto oack;
            }
        }
    }
   
    dp = r_init();
    do {
        size = readit(file, &dp, pf->f_convert);
        if (size < 0) {
            nak(errno + 100);
            goto abort;
        }
        dp->th_opcode = htons((u_short)DATA);
        dp->th_block = htons(block);
        timeout = 0;
        (void) setjmp(timeoutbuf);

send_data:
        if (send(peer, dp, size + 4, 0) != size + 4) {
            syslog(LOG_ERR, "tftpd: write: %m\n");
            goto abort;
        }
        read_ahead(file, pf->f_convert);
        for ( ; ; ) {
            alarm(rexmtval);        /* read the ack */
            n = recv(peer, ackbuf, sizeof (ackbuf), 0);
            alarm(0);
            if (n < 0) {
                syslog(LOG_ERR, "tftpd: read: %m\n");
                goto abort;
            }
            ap->th_opcode = ntohs((u_short)ap->th_opcode);
            ap->th_block = ntohs(ap->th_block);

            if (ap->th_opcode == ERROR)
                goto abort;
           
            if (ap->th_opcode == ACK) {
                if (ap->th_block == block) {
                    break;
                }
                /* Re-synchronize with the other side */
                (void) synchnet(peer);
                if (ap->th_block == (block -1)) {
                    goto send_data;
                }
            }

        }
        block++;
    } while (size == segsize);
abort:
    if (isfilter)
        pclose(file);
    else
        (void) fclose(file);
    isfilter = 0;
}

void justquit(int sig)
{
    exit(0);
}


/*
* Receive a file.
*/
recvfile(pf, oap, oacklen)
    struct formats *pf;
    struct tftphdr *oap;
    int oacklen;
{
    struct tftphdr *dp, *w_init();
    register struct tftphdr *ap;    /* ack buffer */
    register int acksize, n, size;
    u_short block = 0;

    signal(SIGALRM, timer);
    dp = w_init();
    do {
        timeout = 0;

        if (!block++ && oap) {
            ap = (struct tftphdr *)oap;
            acksize = oacklen;
        } else {
            ap = (struct tftphdr *)ackbuf;
            ap->th_opcode = htons((u_short)ACK);
            ap->th_block = htons(block-1);
            acksize = 4;
        }
        (void) setjmp(timeoutbuf);
send_ack:
        if (send(peer, (char *)ap, acksize, 0) != acksize) {
            syslog(LOG_ERR, "tftpd: write: %m\n");
            goto abort;
        }
        write_behind(file, pf->f_convert);
        for ( ; ; ) {
            alarm(rexmtval);
            n = recv(peer, dp, segsize+4, 0);
            alarm(0);
            if (n < 0) {            /* really? */
                syslog(LOG_ERR, "tftpd: read: %m\n");
                goto abort;
            }
            dp->th_opcode = ntohs((u_short)dp->th_opcode);
            dp->th_block = ntohs(dp->th_block);
            if (dp->th_opcode == ERROR)
                goto abort;
            if (dp->th_opcode == DATA) {
                if (dp->th_block == block) {
                    break;   /* normal */
                }
                /* Re-synchronize with the other side */
                (void) synchnet(peer);
                if (dp->th_block == (block-1))
                    goto send_ack;          /* rexmit */
            }
        }
        /*  size = write(file, dp->th_data, n - 4); */
        size = writeit(file, &dp, n - 4, pf->f_convert);
        if (size != (n-4)) {                    /* ahem */
            if (size < 0) nak(errno + 100);
            else nak(ENOSPACE);
            goto abort;
        }
    } while (size == segsize);
    write_behind(file, pf->f_convert);
    if (isfilter)
        pclose(file);
    else
        (void) fclose(file);            /* close data file */
    isfilter = 0;

    ap = (struct tftphdr *)ackbuf;
    ap->th_opcode = htons((u_short)ACK);    /* send the "final" ack */
    ap->th_block = htons(block);
    (void) send(peer, ackbuf, 4, 0);

    signal(SIGALRM, justquit);      /* just quit on timeout */
    alarm(rexmtval);
    n = recv(peer, buf, segsize, 0); /* normally times out and quits */
    alarm(0);
    if (n >= 4 &&                   /* if read some data */
        dp->th_opcode == DATA &&    /* and got a data block */
        block == dp->th_block) {    /* then my last ack was lost */
        (void) send(peer, ackbuf, 4, 0);     /* resend final ack */
    }
abort:
    return;
}

struct errmsg {
    int    e_code;
    const char    *e_msg;
} errmsgs[] = {
    { EUNDEF,    "Undefined error code" },
    { ENOTFOUND,    "File not found" },
    { EACCESS,    "Access violation" },
    { ENOSPACE,    "Disk full or allocation exceeded" },
    { EBADOP,    "Illegal TFTP operation" },
    { EBADID,    "Unknown transfer ID" },
    { EEXISTS,    "File already exists" },
    { ENOUSER,    "No such user" },
    { EOPTNEG,    "Failure to negotiate RFC1782 options" },
    { -1,        0 }
};

/*
* Send a nak packet (error message).
* Error code passed in is one of the
* standard TFTP codes, or a UNIX errno
* offset by 100.
*/
nak(error)
    int error;
{
    register struct tftphdr *tp;
    int length;
    register struct errmsg *pe;
/*    extern char *sys_errlist[];    */

    tp = (struct tftphdr *)buf;
    tp->th_opcode = htons((u_short)ERROR);
    tp->th_code = htons((u_short)error);
    for (pe = errmsgs; pe->e_code >= 0; pe++)
        if (pe->e_code == error)
            break;
    if (pe->e_code < 0) {
        pe->e_msg = sys_errlist[error -100];
        tp->th_code = EUNDEF;   /* set 'undef' errorcode */
    }
    strcpy(tp->th_msg, pe->e_msg);
    length = strlen(pe->e_msg);
    tp->th_msg[length] = '\0';
    length += 5;
    if (debug)
        syslog(LOG_ERR, "Negative acknowledge: %s\n", tp->th_msg);
    if (send(peer, buf, length, 0) != length)
        syslog(LOG_ERR, "nak: %m\n");
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区视频在线| 欧美白人最猛性xxxxx69交| 蜜桃av噜噜一区| 一区二区免费看| 日韩美女啊v在线免费观看| 日韩在线一二三区| 一区二区三区在线视频观看 | 在线欧美日韩精品| 成人免费va视频| 成人黄色电影在线 | 一区二区高清免费观看影视大全| 久久久精品tv| 亚洲国产精品av| 国产精品久久久久久久蜜臀 | 99久久er热在这里只有精品66| 精品一区二区三区香蕉蜜桃 | 亚洲三级理论片| 自拍偷拍欧美精品| 亚洲综合网站在线观看| 三级影片在线观看欧美日韩一区二区 | 欧美本精品男人aⅴ天堂| 欧美大片拔萝卜| 国产亚洲综合色| 中文字幕一区二区三区视频| 亚洲蜜臀av乱码久久精品蜜桃| 亚洲柠檬福利资源导航| 亚洲成av人片一区二区梦乃| 日本亚洲最大的色成网站www| 久久精品国产一区二区三 | 国产清纯在线一区二区www| 欧美激情一区三区| 亚洲激情综合网| 男女男精品视频| 成人黄色在线视频| 7777精品伊人久久久大香线蕉完整版| 精品区一区二区| 国产精品久久久久一区| 亚洲成人自拍网| 国产夫妻精品视频| 欧美日韩一区二区三区高清 | 国产.欧美.日韩| 欧美最新大片在线看| 日韩欧美在线网站| 亚洲美女偷拍久久| 国产精品亚洲专一区二区三区| 99久久精品国产麻豆演员表| 精品国产一区二区三区久久影院| 国产精品日韩精品欧美在线| 午夜一区二区三区在线观看| 丁香六月久久综合狠狠色| 欧美日韩在线免费视频| 国产精品嫩草久久久久| 麻豆国产精品视频| 91国在线观看| 国产精品乱人伦| 精品一区二区三区免费观看| 精品视频一区三区九区| 国产精品免费人成网站| 日本视频免费一区| 91福利在线看| 亚洲久草在线视频| 成人av小说网| 国产日韩影视精品| 国产伦精品一区二区三区免费迷| 正在播放亚洲一区| 亚洲色图另类专区| 99精品久久99久久久久| 国产人妖乱国产精品人妖| 久久激情综合网| 欧美一区二区三区视频在线观看| 亚洲午夜羞羞片| 色综合色综合色综合色综合色综合| 欧美精品一区二区久久婷婷| 日韩成人av影视| 欧美精品三级在线观看| 亚洲香肠在线观看| 欧美午夜精品久久久| 亚洲精品免费电影| 色88888久久久久久影院野外| 最新久久zyz资源站| 99精品视频中文字幕| 中文字幕欧美激情| jizz一区二区| 亚洲欧美日韩电影| 欧洲一区在线观看| 性感美女极品91精品| 欧美日韩aaaaa| 天堂午夜影视日韩欧美一区二区| 欧美无乱码久久久免费午夜一区 | 欧美精品久久天天躁| 午夜免费久久看| 欧美卡1卡2卡| 精品一区二区免费视频| 国产无人区一区二区三区| 国产福利电影一区二区三区| 亚洲欧洲国产日本综合| 欧美日韩视频不卡| 人人精品人人爱| 久久综合精品国产一区二区三区| 国产精品12区| 亚洲精品高清视频在线观看| 欧美日韩电影在线播放| 久久成人18免费观看| 日本一区二区高清| 欧美在线你懂的| 男男成人高潮片免费网站| 国产香蕉久久精品综合网| 成人黄色电影在线| 成人在线视频一区二区| 亚洲综合色区另类av| 精品成人一区二区| 成人av网在线| 五月综合激情网| 久久久久九九视频| 欧洲国产伦久久久久久久| 国内精品国产三级国产a久久| 亚洲视频一区在线| 欧美一区二区二区| 97se亚洲国产综合在线| 国产一区在线观看视频| 亚洲高清一区二区三区| 国产欧美一区二区三区沐欲 | 日韩一区二区精品葵司在线| 成人晚上爱看视频| 亚洲444eee在线观看| 国产精品视频观看| 欧美一级理论片| 色综合色综合色综合色综合色综合 | 欧美性受xxxx黑人xyx| 九九精品一区二区| 亚洲高清不卡在线| 国产精品夫妻自拍| 精品粉嫩超白一线天av| 在线视频一区二区免费| 成人免费av资源| 久久99精品久久只有精品| 亚洲精品高清在线| 国产精品久久久久婷婷二区次 | 国产精品538一区二区在线| 亚洲国产一二三| 一区免费观看视频| 国产目拍亚洲精品99久久精品| 91精品久久久久久蜜臀| 欧美亚洲图片小说| 91免费国产在线观看| 成人三级在线视频| 丰满岳乱妇一区二区三区| 日本成人中文字幕| 天天影视色香欲综合网老头| 一区二区三区中文在线| 亚洲欧美日韩国产手机在线 | 欧美电视剧免费观看| 欧美一区二区精美| 欧美一区欧美二区| 日韩午夜在线影院| 欧美精品色综合| 91精品国产一区二区三区蜜臀| 欧美综合天天夜夜久久| 欧美日韩中文字幕一区二区| 欧美激情综合在线| 欧美韩日一区二区三区四区| 欧美韩日一区二区三区| 中文字幕高清不卡| 中文字幕中文字幕中文字幕亚洲无线 | 欧美日韩国产一区| 欧美三级中文字| 欧美日韩一区二区三区四区| 欧美三级在线看| 日韩一区二区高清| 久久久99精品久久| 国产精品国产三级国产普通话蜜臀| 国产精品入口麻豆九色| 一区二区三区在线视频播放| 天天综合色天天综合色h| 蜜桃精品视频在线| 国产99久久久精品| 色欧美片视频在线观看| 在线综合视频播放| 久久综合色8888| 亚洲欧洲一区二区三区| 亚洲精品自拍动漫在线| 日韩中文字幕1| 国产精品乡下勾搭老头1| 91日韩精品一区| 欧美剧情片在线观看| 精品国产成人在线影院 | 欧美视频在线一区| 欧美一区永久视频免费观看| 国产日韩影视精品| 国产麻豆精品一区二区| 色婷婷综合中文久久一本| 欧美剧情片在线观看| 国产网站一区二区三区| 一区二区三区四区亚洲| 免费不卡在线视频| 91视视频在线观看入口直接观看www | 一区二区不卡在线播放| 久久精品国产99国产| 色综合欧美在线| 亚洲精品在线免费观看视频|