⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 qftp.c

📁 在SYMBIAN平台上用OPEN C实现的一个FTP客户程序
💻 C
字号:
/***************************************************************************//*                                                                         *//* qftp.c - Part of Open C FTP Client                                      *//*                                                                         *//* Copyright (C) 2007 Nokia Corporation                                    *//*                                                                         *//* Open C FTP Client is based on ftplib and qftp by Thomas Pfau.           *//*                                                                         *//* Copyright (C) 1996-2001 Thomas Pfau, pfau@eclipse.net                   *//* 1407 Thomas Ave, North Brunswick, NJ, 08902                             *//*                                                                         *//* This program is free software; you can redistribute it and/or           *//* modify it under the terms of the GNU Library General Public             *//* License as published by the Free Software Foundation; either            *//* version 2 of the License, or (at your option) any later version.        *//*                                                                         *//* This program is distributed in the hope that it will be useful,         *//* but WITHOUT ANY WARRANTY; without even the implied warranty of          *//* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU       *//* Library General Public License for more details.                        *//*                                                                         *//* You should have received a copy of the GNU Library General Public       *//* License along with this program; if not, write to the                   *//* Free Software Foundation, Inc., 59 Temple Place - Suite 330,            *//* Boston, MA 02111-1307, USA.                                             *//*                                                                         *//***************************************************************************/ /* * ============================================================================ *  Name     : qftp from qftp.c *  Part of  : Open C FTP Client *  Created  : 03/12/2007 by Forum Nokia *  Version  : 1.0 * ============================================================================*//* This original code is commented out due to the conversion changes *///#if defined(__unix__) || defined(__VMS)#include <unistd.h>/* This original code is commented out due to the conversion changes *///#endif#include <stdio.h>#include <stdlib.h>#include <string.h>#include <sys/stat.h>/* This original code is commented out due to the conversion changes *//*#if defined(_WIN32)#include <winsock.h>#include <io.h>#include "getopt.h"#endif#if defined(VAX)#include "getopt.h"#endif*/#include "qftp.h"#include "ftplib.h"/* This original code is commented out due to the conversion changes *///#include "getopt.h"void usage(){    printf(        "usage:  %s <host>\n"        "\t[ -l user [ -p pass ] ]  defaults to anonymous/user@hostname\n"        "\t[\n"        "\t  [ -v level ]        debug level\n"        "\t  [ -r rootpath ]     chdir path\n"        "\t  [ -m umask ]        umask for created files\n"        "\t  [ -a | -i ] ]       ascii/image transfer file\n"        "\t  [ -w ]              toggle wildcard mode\n"        "\t  [ file ]            file spec for directory or file to transfer\n"        "\t]...\n\n"        "If no files are specified on command line, the program\n"        "will read file names from stdin.\n", invocation);}void ftp_connect(){//    if (conn)//        return;            if (host == NULL)    {	fprintf(stderr,"Host name not specified\n");	usage();	exit(EX_SYNTAX);    }    if (!logged_in)    {    	if (user == NULL)    	{	    user = "anonymous";	    if (pass == NULL)	    {	    	char *u,h[64];	    	u = getenv("USER");	    	if (gethostname(h,64) < 0)	    	{/* This original code is commented out due to the conversion changes *///		    perror("gethostname");		    exit(EX_NETDB);	    	}	    	if ((u != NULL) && (h != NULL))	    	{		    static char xxx[64];		    sprintf(xxx,"%s@%s",u,h);		    pass = xxx;	    	}	    }    	}	else if (pass == NULL)	{/* This original code is commented out due to the conversion changes *//*#if defined(_WIN32) || defined(VMS)	    exit(EX_LOGIN);#else	    if ((pass = getpass("Password: ")) == NULL)	    {*//* This original code is commented out due to the conversion changes */		exit(EX_SYSERR);//	    }	}/* This original code is commented out due to the conversion changes */	//#endif    	if (!FtpConnect(host,&conn))    	{/* This original code is commented out due to the conversion changes *///      fprintf(stderr,"Unable to connect to node %s\n%s",host,FtpLastResponse(conn));	    exit(EX_CONNECT);    	}    	if (!FtpLogin(user,pass,conn))    	{/* This original code is commented out due to the conversion changes *///	    fprintf(stderr,"Login failure\n%s",FtpLastResponse(conn));	    exit(EX_LOGIN);    	}//	logged_in++;    }}void change_directory(char *root){    ftp_connect();    if (!FtpChdir(root, conn))    {/* This original code is commented out due to the conversion changes *///  fprintf(stderr,"Change directory failed\n%s",FtpLastResponse(conn));	exit(EX_REMCMD);    }}struct REMFILE {    struct REMFILE *next;    int fsz;    char *fnm;};/* This original code is commented out due to the conversion changes *//*static int log_progress(netbuf *ctl, int xfered, void *arg){    struct REMFILE *f = (struct REMFILE *) arg;    int pct = (xfered * 100) / f->fsz;    printf("%s %3d%%\r", f->fnm, pct);    fflush(stdout);    return 1;}*/char* process_file(char *fnm){/* This original code is commented out due to the conversion changes *///  int sts=0;	char* sts="0";    int fsz;    struct REMFILE *filelist = NULL;/* This original code is commented out due to the conversion changes *///  struct REMFILE rem;    ftp_connect();    FtpOptions(FTPLIB_CALLBACK, (long) NULL, conn);    if ((action == FTP_SEND) || (action == FTP_GET))    {	if (action == FTP_SEND)	{	    struct stat info;	    if (stat(fnm,&info) == -1)	    {/* This original code is commented out due to the conversion changes *///          perror(fnm);		return "-1";	    }	    if (S_ISDIR(info.st_mode))	    {/* This original code is commented out due to the conversion changes *//*		if (!ftpMkdir(fnm))	       fprintf(stderr,"mkdir %s failed\n%s",fnm,FtpLastResponse(conn));	    else         if (ftplib_debug)            fprintf(stderr,"Directory %s created\n",fnm);*/		return "-1";	    }            fsz = info.st_size;	}        else        {	    if (!wildcard)	    {		struct REMFILE *f;		f = (struct REMFILE *) malloc(sizeof(struct REMFILE));		memset(f,0,sizeof(struct REMFILE));		f->next = filelist;		filelist = f;		f->fnm = strdup(fnm);	    } else {		netbuf *dir;		char *buf;		if (!FtpAccess(fnm, FTPLIB_DIR, FTPLIB_ASCII, conn, &dir))		{/* This original code is commented out due to the conversion changes *///	        fprintf(stderr,"error requesting directory of %s\n%s\n",//			    fnm, FtpLastResponse(conn));            return "-1";		}		buf = malloc(DIRBUF_SIZE);		while (FtpRead(buf, DIRBUF_SIZE, dir) > 0)		{		    struct REMFILE *f;		    char *p;		    f = (struct REMFILE *) malloc(sizeof(struct REMFILE));		    memset(f,0,sizeof(struct REMFILE));		    f->next = filelist;		    p = strchr(buf,'\n');		    if (p)			*p = '\0';		    f->fnm = strdup(buf);		    filelist = f;		}		free(buf);		FtpClose(dir);	    }        }    }    switch (action)    {      case FTP_DIR :	sts = FtpDir(NULL, fnm, conn);	break;      case FTP_LIST :	sts = FtpNlst(NULL, fnm, conn);	break;      case FTP_SEND :/* This original code is commented out due to the conversion changes *///	rem.next = NULL;//	rem.fnm = fnm;//	rem.fsz = fsz;	fsz /= 10;	if (fsz > 100000)	    fsz = 100000;/* This original code is commented out due to the conversion changes *//*      if (ftplib_debug && fsz)        {            FtpOptions(FTPLIB_CALLBACK, (long) log_progress, conn);            FtpOptions(FTPLIB_IDLETIME, (long) 1000, conn);            FtpOptions(FTPLIB_CALLBACKARG, (long) &rem, conn);            FtpOptions(FTPLIB_CALLBACKBYTES, (long) fsz, conn);        }*/	sts = FtpPut(fnm,fnm,mode,conn);/* This original code is commented out due to the conversion changes *///	if (ftplib_debug && sts)//	    printf("%s sent\n",fnm);	break;      case FTP_GET :	while (filelist)	{	    struct REMFILE *f = filelist;	    filelist = f->next;	    if (!FtpSize(f->fnm, &fsz, mode, conn))		fsz = 0;	    f->fsz = fsz;	    fsz /= 10;	    if (fsz > 100000)		fsz = 100000;/* This original code is commented out due to the conversion changes *//*	    if (ftplib_debug && fsz)	    {		FtpOptions(FTPLIB_CALLBACK, (long) log_progress, conn);		FtpOptions(FTPLIB_IDLETIME, (long) 1000, conn);		FtpOptions(FTPLIB_CALLBACKARG, (long) f, conn);		FtpOptions(FTPLIB_CALLBACKBYTES, (long) fsz, conn);	    }*/	    sts = FtpGet(f->fnm,f->fnm,mode,conn);/* This original code is commented out due to the conversion changes *///	    if (ftplib_debug && sts)//		printf("%s retrieved\n",f->fnm);	    free(f->fnm);	    free(f);	}	break;      case FTP_RM :	while (filelist)	{	    struct REMFILE *f = filelist;	    filelist = f->next;	    sts = FtpDelete(f->fnm,conn);/* This original code is commented out due to the conversion changes *///	    if (ftplib_debug && sts)//		printf("%s deleted\n", f->fnm);	    free(f->fnm);	    free(f);	}	break;    }    if (!sts)    {/* This original code is commented out due to the conversion changes *///  printf("ftp error\n%s\n",FtpLastResponse(conn));    sts = "0";    }    return sts;}void set_umask(char *m){    char buf[80];    sprintf(buf,"umask %s", m);    ftp_connect();    FtpSite(buf, conn);}/* This original code is commented out due to the conversion changes *///void main(int argc, char *argv[])char* qftp_main(int argc, char *argv[]){    int files_processed = 0;    int opt;    invocation = argv[0];    optind = 1;        host = NULL;    if (strstr(argv[0],"send") != NULL)	action = FTP_SEND;    else if (strstr(argv[0],"get") != NULL)	action = FTP_GET;    else if (strstr(argv[0],"dir") != NULL)	action = FTP_DIR;    else if (strstr(argv[0],"list") != NULL)	action = FTP_LIST;    else if (strstr(argv[0],"rm") != NULL)	action = FTP_RM;    if ((action == 0) && (argc > 2))    {	if (strcmp(argv[1],"send") == 0)	    action = FTP_SEND;    	else if (strcmp(argv[1],"get") == 0)	    action = FTP_GET;    	else if (strcmp(argv[1],"dir") == 0)	    action = FTP_DIR;	else if (strcmp(argv[1],"list") == 0)	    action = FTP_LIST;    	else if (strcmp(argv[1],"rm") == 0)	    action = FTP_RM;	if (action)	    optind++;    }    if (action == 0)    {	usage();	exit(EX_SYNTAX);    }    FtpInit();    while (argv[optind] != NULL)    {	if (argv[optind][0] != '-')	{	    if (host == NULL)		host = argv[optind++];	    else	    {		files_processed++;		rvstring = process_file(argv[optind++]);        // added to prevent forever looping while	    argv[optind] = NULL;	    }	    continue;	}	opt = getopt(argc,argv,"ail:m:p:r:v:w");	switch (opt)	{	  case '?' :	    usage();	    exit(EX_SYNTAX);	  case ':' :	    usage();	    exit(EX_SYNTAX);	  case 'a' : mode = 'A'; break;	  case 'i' : mode = 'I'; break;	  case 'l' : user = optarg; break;	  case 'm' : set_umask(optarg); break;	  case 'p' : pass = optarg; break;	  case 'r' : change_directory(optarg); break;	  case 'v' :/* This original code is commented out due to the conversion changes *//*	    if (opt == ':')		ftplib_debug++;	    else		ftplib_debug = atoi(optarg);*/    break;	  case 'w' : wildcard = !wildcard; break;	  default :	    usage();	    exit(EX_SYNTAX);	}    }    if (files_processed == 0)    {	ftp_connect();	if ((action == FTP_DIR) || (action == FTP_LIST))	    process_file(NULL);	else	{	    char fnm[256];	    do	    {	        char *nl;		if (isatty(fileno(stdin)))		    printf("file> ");		if (fgets(fnm, sizeof(fnm), stdin) == NULL)		    break;		if ((nl = strchr(fnm,'\n')) != NULL)		    *nl = '\0';		process_file(fnm);	    }	    while (1);	}    }    if (conn)	FtpClose(conn);    return rvstring;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -