ftp服务器测试
前台传递字符串reqbuf:
ftp服务器IP\r\n端口\r\n用户名\r\n密码\r\nftp路径\r\n\r\n
解析reqbuf,重新组装成系统命令,去执行ftptest.sh脚本,
调用system函数,执行以上系统命令,结果日志打印到/tmp/ftptest.log中,读取日志进行结果判断:如果是230,则登录成功。
登录成功时,日志记录如下:
230 Login successful.
Remote system type is UNIX.
Using binary mode to transfer files.
ip:192.168.51.206
端口:21
用户名:ftp
密码:123456
ftptest.sh脚本:
#!/bin/bash
logfile="/tmp/ftptest.log"
ftp -i -n -v<<EOF>$logfile
open $1 $2 (IP、端口)
user $3 $4 (用户名、密码)
cd $5 (路径)
bye
EOF
测试结果打印到/tmp/ftptest.log,通过查看log文件中的状态码判断测试成功
logroot@webwall:/home/xiachengjiao/nnba/nnba/mise/calls# vi /tmp/ftptest.log
调试日志目录:
Vi /webwall/var/run/debug.ftptest
while(!feof(fp))
{
if(fgets(statusnum, sizeof(statusnum), fp) == NULL)
{
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "get statusnum error!\n");
ERR
}
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "statusnum=%s\n", statusnum);
if((testdir == 0) && ((ackstatus = strncmp(statusnum, "230", 3)) == 0))
{
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "ftp服务登录成功\n");
break;
}
else if((testdir == 1) && ((ackstatus = strncmp(statusnum, "250", 3)) == 0))
{
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "ftp服务器文件路径测试成功\n");
break;
}
}
if(feof(fp))
{
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "ftp服务器测试失败\n");
ERR
}
这个程序不能测试出ip或端口等配置错误的情况。错误出在feof()函数上面;。当/tmp/ftptest.log日志内容如下:
Not connected.
Not connected.
程序执行结果是:
get statusnum error!
程序修改如下:
if(fgets(statusnum, sizeof(statusnum), fp) == NULL)
{
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "get statusnum error!\n");
ERR
}
while(!feof(fp))
{
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "statusnum=%s\n", statusnum);
if((testdir == 0) && ((ackstatus = strncmp(statusnum, "230", 3)) == 0))
{
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "ftp服务登录成功\n");
break;
}
else if((testdir == 1) && ((ackstatus = strncmp(statusnum, "250", 3)) == 0))
{
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "ftp服务器文件路径测试成功\n");
break;
}
#if 0
if(fgets(statusnum, sizeof(statusnum), fp) == NULL)
{
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "get statusnum error!\n");
ERR
}
#endif
fgets(statusnum, sizeof(statusnum), fp);
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "statusnum=%s\n", statusnum);
}
if(feof(fp))
{
DEBUGLOG(IW_LOG_MAINBRANCE, DEBUG, "ftp服务器测试失败\n");
ERR
}
当log日志内容不变时,程序执行结果是
[30881]2013-05-21 15:53:45 ftptest.c[83]: DoService
statusnum=Not connected.
[30881]2013-05-21 15:53:45 ftptest.c[102]: DoService
statusnum=Not connected.
[30881]2013-05-21 15:53:45 ftptest.c[83]: DoService
statusnum=Not connected.
[30881]2013-05-21 15:53:45 ftptest.c[102]: DoService
statusnum=Not connected.
[30881]2013-05-21 15:53:45 ftptest.c[106]: DoService
ftp服务器测试失败
分析:feof(fp)有两个返回值:如果遇到文件结束,函数feof(fp)的值为非零值,否则为0。
EOF是文本文件结束的标志。在文本文件中,数据是以字符的ASCⅡ代码值的形式存放,普通字符的ASCⅡ代码的范围是32到127(十进制),EOF的16进制代码为0x1A(十进制为26),因此可以用EOF作为文件结束标志。[1]
当把数据以二进制形式存放到文件中时,就会有-1值的出现,因此不能采用EOF作为二进制文件的结束标志。为解决这一个问题,ASCI C提供一个feof函数,用来判断文件是否结束。feof函数既可用以判断二进制文件又可用以判断文本文件。
“C”语言的“feof()”函数和数据库中“eof()”函数的运作是完全不同的。数据库中“eof()”函数读取当前指针的位置,“C”语言的“feof()”函数返回的是最后一次“读操作的内容”。多年来把“位置和内容”相混,从而造成了对这一概念的似是而非。
那么,位置和内容到底有何不同呢?举个简单的例子,比如有人说“你走到火车的最后一节车箱”这就是位置。而如果说“请你一直向后走,摸到铁轨结束”这就是内容。也就是说用内容来判断会“多走一节”。这就是完全依赖于“while(!feof(FP)){...}”进行文件复制时,目标文档总会比源文档“多出一些”的原因。
在“C”文件读取操作时不能完全依赖于“while(!feof(FP)){...}”的判断。下面代码是改进后的代码,该代码执行后output文件内容和input文件内容一致,与使用“while(!feof(FP)){...}”相比,input文件的结尾符号(EOF)没有被读入到output文件中。
ftp服务器测试:脚本实现
bug:测试错误的时候不能检测出来。程序逻辑有问题,。,,所以以后做单元测试的时候必须要把可能出现的情况都测试全面。
ftp服务器测试的更多相关文章
- Linux篇---ftp服务器的搭建
一.前述 企业中linux搭建ftp服务器还是很实用的,所以本文针对centoos7和centoos6搭建服务器教程做个总结. 二.具体 1.显示如下图则表示已安装 vsftp软件.如果未显示则需要安 ...
- Java语言实现简单FTP软件------>源码放送(十三)
Java语言实现简单FTP软件------>FTP协议分析(一) Java语言实现简单FTP软件------>FTP软件效果图预览之下载功能(二) Java语言实现简单FTP软件----- ...
- linux系统下修改文件夹目录权限
linux系统下修改文件夹目录权限 文件夹权限问题 Linux.Fedora.Ubuntu修改文件.文件夹权限的方法差不多.很多人开始接触Linux时都很头痛Linux的文件权限问题.这里告诉大家如何 ...
- CentOS7.2下PXE+kickstart自动化安装系统
一.实验环境 操作系统:CentOS Linux release 7.2.1511 (Core) 网卡地址:192.168.100.147/24 光盘镜像:CentOS-7-x86_64-Minima ...
- 综合练习2 设置访问权限,Easy-IP访问外网,内外网访问
实验拓扑图: 实验要求: 1.pc.路由.交换基本配置,vlan间路由互通. 2.vlan20.vlan30可以访问FTP,VLAN10不允许访问FTP. 3.AR1通过easy-ip方式实现私网地址 ...
- yum仓库配置与内网源部署记录
使用yum的好处主要就是在于能够自动解决软件包之间的依赖.这使得维护更加容易.这篇文章主要就是记录部署内网源的操作过程以及yum工具如何使用 因为需要.数据库要从Oracle迁移至MySQL.在部署M ...
- jmeter接口测试笔记
1.接口测试基础 API:Application Programming Interface,即调用应用程序的通道. 接口测试遵循点 接口的功能性实现:检查接口返回的数据与预期结果的一致性. 测试接口 ...
- 『动善时』JMeter基础 — 1、JMeter介绍
1.什么是JMeter Apache JMeter是Apache组织开发的基于Java的压力测试工具,用于对软件做压力测试.它最初被设计用于Web应用测试,但后来扩展到其他测试领域. (Apache ...
- 8.仿阿里云虚拟云服务器的FTP(包括FTP文件夹大小限制)
平台之大势何人能挡? 带着你的Net飞奔吧!:http://www.cnblogs.com/dunitian/p/4822808.html#iis 原文:http://dnt.dkill.net/Ar ...
随机推荐
- 03_天气查询_socket方式模拟_多线程方式
[简述] 要重视Socket开发,企业后台服务特长使用Socket. 1.服务端要有可持续运行能力,保证线程一致在运行 2.并发处理能力,使用多线程 [工程截图] [WeatherRunner.jav ...
- Dynamic Programming: From novice to advanced
作者:Dumitru 出处:http://community.topcoder.com/tc?module=Static&d1=tutorials&d2=dynProg An impo ...
- 在ecshop商品详情页显示供货商
好久没写文章了,隐约记得前几天有人问到这个问题:[如何在ecshop商品详情页面显示该商品的供货商?] 今天有时间整理下,分享给大家. 注:以下修改适用于ecshop2.7.2,其他版本未做测试. 1 ...
- share my tools With Xcode
1.让Xcode的控制台支持LLDB类型的打印 在Xcode断点调试的时候, 在控制台输入 po self.view.frame 或者 po id 类型的时候就死翘翘了. 进入正题: 安装LLDB调试 ...
- 分享 - Social.framework
/** * 第三方分享 * * @param void 友盟分享 * @param shareSDK * @param 百度分享 */ #import "ViewController ...
- MYSQL数据库备份与恢复【转】
mysqldump -h主机名 -P端口 -u用户名 -p密码 (–database) 数据库名 > 文件名.sql 在window上需要通过CMD进入mysql安装目录下的bin目录下执行 ...
- mcd, lm, VS lx
LED常识之 mcd&lm&w的关系 转载自:http://1198.vip.blog.163.com/blog/static/202177117201211624535412/ LE ...
- Pentaho Data Integration (二) Spoon
上一篇:Pentaho Data Integration笔记 (一):安装 介绍 Spoon Intoduction site: http://wiki.pentaho.com/display/EAI ...
- 【转载】C# HttpWebRequest 发送SOAP XML
调用webservice的几种方法: 方法一:添加web引用(简单/方便 局限客户端是.net) 方法二:Post xml(本文重点讲述) 方法三:使用微软MSXML2组件(好像在window ser ...
- java 堆与栈的区别
1. 堆与栈的区别? 1-1. 数据存放位置: 数据都存放于RAM (Random Access Memory). 1-2. 存放数据的类型:stack栈中保存方法中的基本数据类型(int, do ...