原文转自 http://blog.csdn.net/supersonico/article/details/18900319

一.用VC++来编写TCP 服务器/客户端的简单程序。

注意事项:

1.要加载ws2_32.lib链接库。

项目->属性->弹出属性页->连接器->输入->附加依赖项

2.要使用#include <WinSock2.h>头文件。

实现步骤:

1.服务器端:

①加载套接字库 (可以直接从MSDN上复制  WSAStartup)

②创建socket

③绑定socket(bind)

④将socket设置成监听状态(listen)

⑤等待客户端的访问(accept)

⑥接收客户端信息(recv)

⑦往客户端发送信息(send)

⑧关闭套接字(closesocket)

⑨清除套接字库(WSACleanup)

#include <iostream>
#include <WinSock2.h>
#include <stdlib.h>
using namespace std; void main()
{
//加载套接字
WORD wVersionRequested;
WSADATA wsaData;
int err; wVersionRequested = MAKEWORD(, ); err = WSAStartup(wVersionRequested, &wsaData);
if (err != )
{
return;
}
if (LOBYTE(wsaData.wVersion) != || HIBYTE(wsaData.wVersion) != )
{
WSACleanup();
return;
} //创建用于监听的套接字
SOCKET sockSrv = socket(AF_INET, SOCK_STREAM, ); SOCKADDR_IN addrSrv;
addrSrv.sin_addr.S_un.S_addr = htonl(INADDR_ANY);
addrSrv.sin_family = AF_INET;
addrSrv.sin_port = htons(); //绑定套接字
bind(sockSrv, (SOCKADDR*)&addrSrv, sizeof(SOCKADDR));
//将套接字设置为监听模式
listen(sockSrv, ); SOCKADDR_IN addrClient;
int len = sizeof(SOCKADDR); while ()
{
//等待客户的请求到来
SOCKET sockConn = accept(sockSrv, (SOCKADDR*)&addrClient, &len);
char sendBuf[];
sprintf_s(sendBuf, , "Welcome %s", inet_ntoa(addrClient.sin_addr)); //发送数据
send(sockConn, sendBuf, strlen(sendBuf) + , );
char recvBuf[];
//接受数据
recv(sockConn, recvBuf, , );
//打印接受的数据
printf("%s\n", recvBuf);
//关闭套接字
closesocket(sockConn);
}
}

2.客户端:

①加载套接字库

②向服务器发送请求 connect

③接受服务器的信息 recv

④向服务器发送信息 send

⑤关闭套接字 closesocket

⑥清除套接字库 WSACleanup

#include <iostream>
#include <WinSock2.h>
#include <stdlib.h>
using namespace std; void main()
{
//加载套接字
WORD wVersionRequested;
WSADATA wsaData;
int err; wVersionRequested = MAKEWORD(, ); err = WSAStartup(wVersionRequested, &wsaData);
if (err != )
{
return;
}
if (LOBYTE(wsaData.wVersion) != || HIBYTE(wsaData.wVersion) != )
{
WSACleanup();
return;
} //创建套接字
SOCKET socketClient = socket(AF_INET, SOCK_STREAM, );
//向服务器发送请求
SOCKADDR_IN sockAddrClient;
sockAddrClient.sin_addr.S_un.S_addr = inet_addr("120.77.57.44");
sockAddrClient.sin_family = AF_INET;
sockAddrClient.sin_port = htons(); if (SOCKET_ERROR == connect(socketClient, (SOCKADDR*)&sockAddrClient, sizeof(SOCKADDR)))
{
closesocket(socketClient);
WSACleanup();
return;
}
//接受信息
char recvBuf[];
recv(socketClient, recvBuf, , );
printf("%s\n", recvBuf);
//发送数据
send(socketClient, "This is lisi", strlen("This is lisi") + , );
//关闭套接字
closesocket(socketClient);
WSACleanup();
cin.get();
cin.get();
}

二.用VC++来编写UDP 服务器/客户端的简单程序。

1.服务器端:

①加载套接字库(WSAstartup)

②创建socket

③绑定socket(bind)

④接受从客户端发来的信息(recvfrom)

⑤关闭套接字(closesocket)

⑥清空套接字库(WSAClearup)

#include <iostream>
#include <stdlib.h>
#include <WinSock2.h> using namespace std; void main()
{
//加载套接字
WORD wVersionRequested;
WSADATA wsaData;
int err; wVersionRequested = MAKEWORD(,); err = WSAStartup(wVersionRequested,&wsaData);
if (err != )
{
return ;
}
if (LOBYTE(wsaData.wVersion)!= || HIBYTE(wsaData.wVersion)!=)
{
WSACleanup();
return ;
} //创建套接字
SOCKET sockSrv = socket(AF_INET,SOCK_DGRAM,); SOCKADDR_IN sockAddrSrv;
sockAddrSrv.sin_addr.S_un.S_addr = htonl(INADDR_ANY);
sockAddrSrv.sin_family = AF_INET;
sockAddrSrv.sin_port = htons();
//绑定套接字
bind(sockSrv,(SOCKADDR*)&sockAddrSrv,sizeof(SOCKADDR)); SOCKADDR_IN sockAddrClient;
int len = sizeof(SOCKADDR);
char recvBuf[];
//接受客户端信息
recvfrom(sockSrv,recvBuf,,,(SOCKADDR*)&sockAddrClient,&len);
printf("%s\n",recvBuf); //关闭套接字
closesocket(sockSrv);
//清除套接字库
WSACleanup();
cin.get();
cin.get();
}

2.客户端:

①加载套接字库 (WSAstartup)

②创建socket

③发送数据(sendto)

④关闭套接字(closesocket)

⑤清空套接字库(WSAClearup)

#include <iostream>
#include <stdlib.h>
#include <WinSock2.h> using namespace std; void main()
{
//加载套接字
WORD wVersionRequested;
WSADATA wsaData;
int err; wVersionRequested = MAKEWORD(,); err = WSAStartup(wVersionRequested,&wsaData);
if (err != )
{
return ;
}
if (LOBYTE(wsaData.wVersion)!= || HIBYTE(wsaData.wVersion)!=)
{
WSACleanup();
return ;
}
//创建套接字
SOCKET sockClient = socket(AF_INET,SOCK_DGRAM,); SOCKADDR_IN sockAddrSrv;
sockAddrSrv.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");
sockAddrSrv.sin_family = AF_INET;
sockAddrSrv.sin_port = htons(); //char sendBuf[100];
sendto(sockClient,"Hello",strlen("Hello")+,,(SOCKADDR*)&sockAddrSrv,sizeof(SOCKADDR));
closesocket(sockClient);
WSACleanup();
cin.get();
cin.get();
}

孙鑫 VC++深入详解第14课——TCP通信/UDP通信(转)的更多相关文章

  1. 孙鑫视频VC++深入详解学习笔记

    孙鑫视频VC++深入详解学习笔记 VC++深入详解学习笔记 Lesson1: Windows程序运行原理及程序编写流程 Lesson2: 掌握C++基本语法 Lesson3: MFC框架程序剖析 Le ...

  2. 孙鑫VC++视频教程(1-20课全)

    孙鑫VC++视频教程(1-20课全)PPT讲义和源代码 http://down.51cto.com/data/467760 孙鑫VC++从入门到精通开发详解视频教程[20讲] http://down. ...

  3. 孙鑫VC学习笔记:多线程编程

    孙鑫VC学习笔记:多线程编程 SkySeraph Dec 11st 2010  HQU Email:zgzhaobo@gmail.com    QQ:452728574 Latest Modified ...

  4. VC++深入详解-第五章学习心得

    这一章节主要讲解了文本相关的一些编程 插入符的使用 CreateSolidCaret(100,200);//插入符的宽度和高度 ShowCaret(); 插入符的一般使用方法 int CTestVie ...

  5. 《VC++ 深入详解》 第3版 这是盗版书么~。。。

    <VC++ 深入详解> 第3版 www.broadview.com.cn 书读到一小半,发现书重复了一部分,缺失一部分.... 难受~ 比较难继续下去了 有一样的小伙伴么~ <VC+ ...

  6. 《TCP-IP详解卷3:TCP 事务协议、HTTP、NNTP和UNIX域协议》【PDF】下载

    TCP-IP详解卷3:TCP 事务协议.HTTP.NNTP和UNIX域协议>[PDF]下载链接: https://u253469.pipipan.com/fs/253469-230062539 ...

  7. VC++使用socket进行TCP、UDP通信实例总结

    1.        两台计算机通信需要协议,通信的两台计算机IP必须唯一 2.        同一个计算机可以进行多个应用程序与其他计算机通信,IP地址唯一,而端口号是区别同一计算机(同一IP)的唯一 ...

  8. 孙鑫VC++视频教程笔记

    写在前面的话:在学习孙鑫老师的VC++视频时,为了加深自己对知识的深入理解,就做了下面的笔记. 第一讲: 第二讲: 第三讲: 第四讲: 第五讲: 第六讲: 第七讲: 第八讲: 第九讲: 第十讲: 第十 ...

  9. 孙鑫VC学习系列教程

    教程简介 1.循序渐进 从Win32SDK编程开始讲解,帮助大家理解掌握Windows编程的核心 -- 消息循环机制. 2.通俗易懂 编程语言枯燥难懂,然而通过孙鑫老师形象化的讲解,Windows和M ...

随机推荐

  1. 笔记-爬虫-selenium常用方法

    笔记-爬虫-selenium常用方法 1.      查找元素 常用的查找方法 find_element_by_name find_element_by_xpath find_element_by_l ...

  2. 集合源码分析之 HashSet

    一 知识准备 HashSet 是Set接口的实现类,Set存在的最大意义区别于List就是,Set中存放的元素不能够重复,就是不能够有两个相同的元素存放在Set中,那么怎样的两个元素才算是相同的,这里 ...

  3. how to export chrome speed dial extension?

    locate chrome-extension_dgpdioedihjhncjafcpgbbjdpbbkikmi_0.localstorage, copy it to you want, everyt ...

  4. 《Cracking the Coding Interview》——第4章:树和图——题目6

    2014-03-19 04:16 题目:找出一棵二叉搜索树中的中序遍历后继节点,每个节点都有指针指向其父节点. 解法1:分两种情况:向下走时,先右后左:向上走时,先左后右.如果目标节点有右子树,就向右 ...

  5. 《Cracking the Coding Interview》——第4章:树和图——题目4

    2014-03-19 03:40 题目:给定一棵二叉树,把每一层的节点串成一个链表,最终返回一个链表数组. 解法:前序遍历,遍历的同时向各个链表里添加节点.水平遍历好像还不如前序遍历来得方便. 代码: ...

  6. Python 推导式推导序列

    推导式是从一个或多个迭代器快速创建序列的方法.它可以将循环和条件判断结合,从而避免冗长的代码. 一.列表推导式 语法: [表达式 for item in 可迭代对象] [表达式 for item in ...

  7. python负数除法与模运算

    1.负数除法: >>> print 45/76>>> print -45/7-7 >>> print 45/-7-7 >>> p ...

  8. Python全栈工程师(while、占位符)

    ParisGabriel     Python 入门基础         UnicodeASCII 用8个位表示文字 ,最高位一定是零,低七位表示数值Unicode是由16个位组成的(65535) 最 ...

  9. Mysql DISTINCT问题

    问题描述 因为要设计一个数据库表,进行一个倒序去重的操作. 例如: id Name 1 B 2 A 3 A 4 C 5 C 6 B 场景:例如说我们需要得到一个用户的搜索记录,那么肯定不会仅仅根据时间 ...

  10. Spring 笔记(一)概念梳理

    概念 预备知识 1. POJO POJO是Plain Old Java Object的缩写,是软件开发大师Martin Fowler提出的一个概念,指的是一个普通Java类.也就说,你随便编写一个Ja ...