c语言实现ftp网络应用程序,使用C语言socket实现windows pc与ftp服务器通信---socket实现ftp客户端...

code

// Client.cpp : 定义控制台应用程序的入口点。

//

#include "stdafx.h"

#include

#include

#include

#pragma comment(lib,"WS2_32.lib")

using namespace std;

#define PORT 21//FTP端口

#define IP_ADDR "x.x.x.x"//主机地址

int getPortNum(char* buf);

bool executeFTPCmd(SOCKET controlSocket, char* buf, int len, int stateCode);

int getStateCode(char* buf);

int main()

{

WSADATA dat;

SOCKET controlSocket, dataSocket;

SOCKADDR_IN serverAddr;

int dataPort, ret, stateCode;

char buf[100]={0}, sendBuf[1024]={0};

//初始化,很重要

if (WSAStartup(MAKEWORD(2,2),&dat)!=0)//Windows Sockets Asynchronous启动

{

cout<

system("pause");

return -1;

}

//创建Socket

controlSocket=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);

if(controlSocket==INVALID_SOCKET)

{

cout<

system("pause");

return -1;

}

//构建服务器访问参数结构体

serverAddr.sin_family=AF_INET;

serverAddr.sin_addr.S_un.S_addr=inet_addr(IP_ADDR);//地址

serverAddr.sin_port=htons(PORT);//端口

memset(serverAddr.sin_zero,0,sizeof(serverAddr.sin_zero));

//连接

ret=connect(controlSocket,(struct sockaddr*)&serverAddr,sizeof(serverAddr));

if(ret==SOCKET_ERROR)

{

cout<

system("pause");

return -1;

}

cout<

//接收返回状态信息

recv(controlSocket,buf,100,0);

cout<

//根据返回信息提取状态码,进行判断

if(getStateCode(buf) != 220)

{

cout<

system("pause");

exit(-1);

}

//用户名

memset(buf,0,100);

sprintf(buf,"USER %s\r\n","xxxx");

executeFTPCmd(controlSocket, buf, 100, 331);//331

//密码

memset(buf,0,100);

sprintf(buf,"PASS %s\r\n","xxxx");

executeFTPCmd(controlSocket, buf, 100, 230);//230

//=======================================

//切换到被动模式

memset(buf,0,100);

sprintf(buf,"PASV\r\n");

executeFTPCmd(controlSocket, buf, 100, 227);//227

//返回的信息格式为---h1,h2,h3,h4,p1,p2

//其中h1,h2,h3,h4为服务器的地址,p1*256+p2为数据端口

dataPort=getPortNum(buf);

//客户端数据传输socket

dataSocket=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);

serverAddr.sin_port=htons(dataPort);//更改连接参数中的port值

ret=connect(dataSocket,(struct sockaddr*)&serverAddr,sizeof(serverAddr));

if(ret==SOCKET_ERROR)

{

cout<

system("pause");

return -1;

}

cout<

//更改当前目录

memset(buf,0,100);

sprintf(buf,"CWD %s\r\n","/ftpxxxx/web/monitor");//250

executeFTPCmd(controlSocket, buf, 100, 250);

//上传文件

memset(buf,0,100);

sprintf(buf,"STOR %s\r\n","1.jpg");

executeFTPCmd(controlSocket, buf, 100, 125);//125

FILE* f=fopen("1.jpg","rb");

if(f==NULL)

{

cout<

cout<

exit(-1);

}

while( !feof(f) )

{

fread(sendBuf, 1, 1024, f);

send(dataSocket, sendBuf, 1024, 0);

}

fclose(f);

//释放资源

closesocket(dataSocket);

closesocket(controlSocket);

WSACleanup();

system("pause");

return 0;

}

//从返回信息“227 Entering Passive Mode (182,18,8,37,10,25).”中

//获取数据端口

int getPortNum(char* buf)

{

int num1=0,num2=0;

char* p=buf;

int cnt=0;

while( 1 )

{

if(cnt == 4 && (*p) != ',')

{

num1 = 10*num1+(*p)-'0';

}

if(cnt == 5)

{

num2 = 10*num2+(*p)-'0';

}

if((*p) == ',')

{

cnt++;

}

p++;

if((*p) == ')')

{

break;

}

}

cout<

return num1*256+num2;

}

//通过控制socket执行FTP命令

bool executeFTPCmd(SOCKET controlSocket, char* buf, int len, int stateCode)

{

send(controlSocket, buf, len, 0);

memset(buf, 0, len);

recv(controlSocket, buf, 100, 0);

cout<

if(getStateCode(buf) == stateCode)

{

return true;

}

else

{

cout<

return false;

}

}

//从返回信息中获取状态码

int getStateCode(char* buf)

{

int num=0;

char* p=buf;

while(p != NULL)

{

num=10*num+(*p)-'0';

p++;

if(*p==' ')

{

break;

}

}

return num;

}

0818b9ca8b590ca3270a3433284dd417.png

0818b9ca8b590ca3270a3433284dd417.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/475072.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode 562. 矩阵中最长的连续1线段(DP)

文章目录1. 题目2. 解题1. 题目 给定一个01矩阵 M&#xff0c;找到矩阵中最长的连续1线段。 这条线段可以是水平的、垂直的、对角线的或者反对角线的。 示例: 输入: [[0,1,1,0],[0,1,1,0],[0,0,0,1]] 输出: 3 提示: 给定矩阵中的元素数量不会超过 10,000。来源&#xff1a;力…

LeetCode 1151. 最少交换次数来组合所有的 1(滑动窗口)

文章目录1. 题目2. 解题1. 题目 给出一个二进制数组 data&#xff0c;你需要通过交换位置&#xff0c;将数组中 任何位置 上的 1 组合到一起&#xff0c;并返回所有可能中所需 最少的交换次数。 示例 1&#xff1a; 输入&#xff1a;[1,0,1,0,1] 输出&#xff1a;1 解释&#…

LeetCode 742. 二叉树最近的叶节点(建立父节点信息+BFS)

文章目录1. 题目2. 解题1. 题目 给定一个 每个结点的值互不相同 的二叉树&#xff0c;和一个目标值 k&#xff0c;找出树中与目标值 k 最近的叶结点。 这里&#xff0c;与叶结点 最近 表示在二叉树中到达该叶节点需要行进的边数与到达其它叶结点相比最少。 而且&#xff0c;当…

LeetCode 490. 迷宫(BFS/DFS)

文章目录1. 题目2. 解题2.1 BFS2.2 DFS1. 题目 由空地和墙组成的迷宫中有一个球。 球可以向上下左右四个方向滚动&#xff0c;但在遇到墙壁前不会停止滚动。 当球停下时&#xff0c;可以选择下一个方向。 给定球的起始位置&#xff0c;目的地和迷宫&#xff0c;判断球能否在目…

LeetCode 505. 迷宫 II(BFS / Dijkstra 最短路径)

文章目录1. 题目2. 解题2.1 BFS2.2 Dijkstra 最短路径1. 题目 由空地和墙组成的迷宫中有一个球。 球可以向上下左右四个方向滚动&#xff0c;但在遇到墙壁前不会停止滚动。 当球停下时&#xff0c;可以选择下一个方向。 给定球的起始位置&#xff0c;目的地和迷宫&#xff0c…

红米note3android版本,小米-红米note3-LOS-安卓9.0.0-稳定版Stable3.0-来去电归属-农历等-本地化增强适配...

制作者&#xff1a;MOS-Developer基于版本&#xff1a;LineageOS Android最新安卓9.0.0代码适合机型&#xff1a;小米红米note3高配/标配/低配/kenzo注意事项&#xff1a;为了能一直更新和维护&#xff0c;不付费不收费&#xff0c;请把预装的4个软件使用3-5天后再卸载&#xf…

LeetCode 305. 岛屿数量 II(并查集)

文章目录1. 题目2. 解题2.1 超时解2.1 改进计算方法1. 题目 假设你设计一个游戏&#xff0c;用一个 m 行 n 列的 2D 网格来存储你的游戏地图。 起始的时候&#xff0c;每个格子的地形都被默认标记为「水」。 我们可以通过使用 addLand 进行操作&#xff0c;将位置 (row, col)…

LeetCode 265. 粉刷房子 II(DP)

文章目录1. 题目2. 解题1. 题目 假如有一排房子&#xff0c;共 n 个&#xff0c;每个房子可以被粉刷成 k 种颜色中的一种&#xff0c;你需要粉刷所有的房子并且使其相邻的两个房子颜色不能相同。 当然&#xff0c;因为市场上不同颜色油漆的价格不同&#xff0c;所以房子粉刷成…

鸿蒙系统笔记本价格,鸿蒙系统手机华为P50将明年3月发售,华为P40价格骤降至冰点...

原标题&#xff1a;鸿蒙系统手机华为P50将明年3月发售&#xff0c;华为P40价格骤降至冰点鸿蒙系统手机华为P50将明年3月发售&#xff0c;华为P40价格骤降至冰点&#xff01;每一代P系列产品都基于华为研发和业界合作伙伴的最前沿的能力&#xff0c;实现全新的突破&#xff0c;明…

LeetCode 272. 最接近的二叉搜索树值 II(栈+优先队列)

文章目录1. 题目2. 解题1. 题目 给定一个不为空的二叉搜索树和一个目标值 target&#xff0c;请在该二叉搜索树中找到最接近目标值 target 的 k 个值。 注意&#xff1a; 给定的目标值 target 是一个浮点数 你可以默认 k 值永远是有效的&#xff0c;即 k ≤ 总结点数 题目保证…

LeetCode 750. 角矩形的数量(DP)

文章目录1. 题目2. 解题1. 题目 给定一个只包含 0 和 1 的网格&#xff0c;找出其中角矩形的数量。 一个「角矩形」是由四个不同的在网格上的 1 形成的轴对称的矩形。 注意只有4角的位置才需要为 1。并且&#xff0c;4 个 1 需要是不同的。 示例 1&#xff1a; 输入&#xf…

LeetCode 267. 回文排列 II(回溯)

文章目录1. 题目2. 解题1. 题目 给定一个字符串 s &#xff0c;返回其通过重新排列组合后所有可能的回文字符串&#xff0c;并去除重复的组合。 如不能形成任何回文排列时&#xff0c;则返回一个空列表。 示例 1&#xff1a; 输入: "aabb" 输出: ["abba"…

html canvas直线进度条,js+HTML5 canvas 实现简单的加载条(进度条)功能示例

本文实例讲述了jsHTML5 canvas 实现简单的加载条(进度条)功能。分享给大家供大家参考&#xff0c;具体如下&#xff1a;www.jb51.net canvas实现加载条动画/** 获取canvas, canvas本身没有画图能力&#xff0c;相当于一个画布&#xff0c;提供绘制图形的地方* document.getElem…

android 打开移动开关,教你一个让安卓手机运行更流畅的小技巧:打开这个开关即可...

原标题&#xff1a;教你一个让安卓手机运行更流畅的小技巧&#xff1a;打开这个开关即可安卓用户对于“系统优化”这个词一定不会陌生&#xff0c;因为Android系统越用越卡的毛病难以解决&#xff0c;必须进行优化才能保持流畅。那么如何调教才能让爱机达到最快的运行速度呢&am…

matplotlib 绘制梯度下降求解过程

机器学习过程中经常需要可视化&#xff0c;有助于加强对模型和参数的理解。 下面对梯度下降过程进行动图演示&#xff0c;可以修改不同的学习率&#xff0c;观看效果。 import numpy as np import matplotlib.pyplot as plt from IPython import displayX 2*np.random.rand(…

LeetCode 132. 分割回文串 II(DP)

文章目录1. 题目2. 解题1. 题目 给定一个字符串 s&#xff0c;将 s 分割成一些子串&#xff0c;使每个子串都是回文串。 返回符合要求的最少分割次数。 示例: 输入: "aab" 输出: 1 解释: 进行一次分割就可将 s 分割成 ["aa","b"] 这样两个回文…

html无框架,HTML框架技术详例

要将几个.html文件放入一个文件夹//UntitledFrameset-2.html 源码--------------------------------主框架//UntitledFrame-2.html源码------------------------------无标题文档XXXXX系统//UntitledFrame-3.html源码------------------------------无标题文档用户管理用户查询…

LeetCode 第 30 场双周赛(477/2545,前18.7%,第2次全部通过)

文章目录1. 比赛结果2. 题目1. LeetCode 5177. 转变日期格式 easy2. LeetCode 5445. 子数组和排序后的区间和 medium3. LeetCode 5446. 三次操作后最大值与最小值的最小差 medium4. LeetCode 5447. 石子游戏 IV hard&#xff08;博弈DP&#xff09;1. 比赛结果 时隔近5个月&am…

wp博客链接.html,WordPress博客文章标题链接到自定义网址链接

WordPress 支持多种文章形式&#xff0c;相信不少博主遇到过需要把wordpress文章的标题链接到自定义的URL地址的情况&#xff0c;点击文章链接时不是直接访问文章详情页面&#xff0c;而是直接访问分享的链接网页&#xff0c;就像微博一样。要实现这种效果&#xff0c;可以使用…

LeetCode 第 197 场周赛(468/5273,前8.88%)

文章目录1. 比赛结果2. 题目1. LeetCode 5460. 好数对的数目 easy2. LeetCode 5461. 仅含 1 的子串数 medium3. LeetCode 5211. 概率最大的路径 medium&#xff08;Dijkstra&#xff09;4. LeetCode 5463. 服务中心的最佳位置 hard&#xff08;最优化退火算法&#xff09;1. 比…