socket实践编程1
1、服务器端程序编写
(1)、socket
(2)、bind
(3)、listen
(4)、accept,返回值是一个fd,accept正确返回就表示我们已经和前来连接我的客户端之间建立了一个TCP连接了,以后我们就要通过这个连接来和客户端进行读写操作,读写操作就需要一个fd,这个fd就由accept来返回的了。
注意:socket返回的fd叫做监听fd,是用来监听客户端的,不能用来和任何客户端进行读写;accept返回的fd叫做连接fd,用来和连接那端的客户端程序进行读写。
#include <stdio.h>
#include <sys/types.h> /* See NOTES */
#include <sys/socket.h>
#include <arpa/inet.h> #define MTPORT 9003
#define SERADDR "192.168.1.109"
#define BACKLOG 100
int main(void)
{
//第一步,先socket打开文件描述符
int sockfd = -,ret = -;
socklen_t len = ;
struct sockaddr_in seraddr = {};
struct sockaddr_in cliaddr = {}; sockfd = socket(AF_INET,SOCK_STREAM,);
if(sockfd == -)
{
perror("socket error.\n");
return -;
}
printf("socket success,sockfd = %d.\n",sockfd); //第二步,bind绑定sockfd和当前电脑的ip地址&端口号
seraddr.sin_family = AF_INET; //设置地址族为IPv4
seraddr.sin_port = htons(MTPORT); //设置地址的端口号信息
seraddr.sin_addr.s_addr = inet_addr(SERADDR); //设置ip地址
ret = bind(sockfd, (const struct sockaddr *)&seraddr,sizeof(seraddr));
if(ret < )
{
perror("bind");
return -;
}
printf("bind success.\n"); //第三步:listen监听端口
ret = listen(sockfd,BACKLOG);
if(ret < )
{
perror("listen");
return -;
}
//第四步:accept阻塞等待客户端接入
ret = accept(sockfd,(struct sockaddr *)&cliaddr,&len);
printf("hahah.\n");
return ;
}
2、客户端程序编写
(1)、socket
(2)、connect
概念:端口号,实质就是一个数字编号,用来在我们一台主机中(主机的操作系统中)唯一的标识一个能上网的进程。端口号和IP地址一起会被打包到当前的进程发出或者接收到的每一个数据包中。每一个数据包将来在网络上传递的时候,内部都包含了发送方和接收方的消息(就是IP地址和端口号),所以IP地址和端口号这两个往往是打包在一起不分家的。
#include <stdio.h>
#include <sys/types.h> /* See NOTES */
#include <sys/socket.h>
#include <arpa/inet.h> #define CLIPORT 9003 //这里是服务器开放给我们的ip地址和端口号
#define SERADDR "192.168.1.109" int main(void)
{
//第一步,先socket打开文件描述符
int sockfd = -,ret = -;
struct sockaddr_in seraddr = {};
//第一步:socket
sockfd = socket(AF_INET,SOCK_STREAM,);
if(sockfd == -)
{
perror("socket error.\n");
return -;
}
printf("socket success,sockfd = %d.\n",sockfd); //第二步,connect连接服务器
seraddr.sin_family = AF_INET; //设置地址族为IPv4
seraddr.sin_port = htons(CLIPORT); //设置地址的端口号信息
seraddr.sin_addr.s_addr = inet_addr(SERADDR); //设置ip地址
ret = connect(sockfd, (const struct sockaddr *)&seraddr,sizeof(seraddr));
if(ret < )
{
perror("connect");
return -;
}
printf("connect success,ret = %d.\n",ret); return ;
}
socket实践编程1的更多相关文章
- (五)socket实践编程
1.服务器端程序编写 (1)socket(2)bind(3)listen(4)accept,返回值是一个fd,accept正确返回就表示我们已经和前来连接我的客户端之间建立了一个TCP连接了,以后我们 ...
- 25 python socket网络编程
一 客户端/服务器架构 1.硬件C/S架构(打印机) 2.软件C/S架构 互联网中处处是C/S架构 如黄色网站是服务端,你的浏览器是客户端(B/S架构也是C/S架构的一种) 腾讯作为服务端为你提供视频 ...
- Linux Socket 网络编程
Linux下的网络编程指的是socket套接字编程,入门比较简单.在学校里学过一些皮毛,平时就是自学玩,没有见识过真正的socket编程大程序,比较遗憾.总感觉每次看的时候都有收获,但是每次看完了之后 ...
- Python Socket 网络编程
Socket 是进程间通信的一种方式,它与其他进程间通信的一个主要不同是:它能实现不同主机间的进程间通信,我们网络上各种各样的服务大多都是基于 Socket 来完成通信的,例如我们每天浏览网页.QQ ...
- Python全栈【Socket网络编程】
Python全栈[socket网络编程] 本章内容: Socket 基于TCP的套接字 基于UDP的套接字 TCP粘包 SocketServer 模块(ThreadingTCPServer源码剖析) ...
- python之Socket网络编程
什么是网络? 网络是由节点和连线构成,表示诸多对象及其相互联系.在数学上,网络是一种图,一般认为专指加权图.网络除了数学定义外,还有具体的物理含义,即网络是从某种相同类型的实际问题中抽象出来的模型.在 ...
- Python之路【第七篇】python基础 之socket网络编程
本篇文章大部分借鉴 http://www.cnblogs.com/nulige/p/6235531.html python socket 网络编程 一.服务端和客户端 BS架构 (腾讯通软件:ser ...
- Socket网络编程-基础篇
Socket网络编程 网络通讯三要素: IP地址[主机名] 网络中设备的标识 本地回环地址:127.0.0.1 主机名:localhost 端口号 用于标识进程的逻辑地址 有效端口:0~65535 其 ...
- Socket网络编程--FTP客户端
Socket网络编程--FTP客户端(1)(Windows) 已经好久没有写过博客进行分享了.具体原因,在以后说. 这几天在了解FTP协议,准备任务是写一个FTP客户端程序.直接上干货了. 0.了解F ...
随机推荐
- XPath--快速获取XML数据的节点或属性
转载自 XPath可以快速定位到Xml中的节点或者属性.XPath语法很简单,但是强大够用,它也是使用xslt的基础知识.示例Xml: <?xml version="1.0" ...
- qt 中图表 QtCharts 的使用
要使用QtCharts 需要几个步骤: 1. pro 文件中 修改 QT += charts 2. 把 chart 相关的头文件放在 ui 相关的头文件上面,否则会导致 编译错误,找不到 chartV ...
- 算法实战(六)Z 字形变换
一.前言 之前因为第五题最长回文字符串需要使用到dp解法,所以我花了很长的时间来研究dp(因为每天又要上班,加上这段时间事情比较多,所以花了三个星期才搞定),好不容易算入了个门,有兴趣的同学可以看看我 ...
- inkscape批量将svg转为pdf
for i in *.svg;do inkscape --export-pdf=${i%.*}.pdf $i;done
- 2020/2/17 zzcms8.2 PHP代码审计
0x00 看网站结构 ********************************* * * * ZZCMS产品版目录结构 * * * ****************************** ...
- P1303 A*B Problem(高精度乘法)
P1303 A*B Problem 模拟就好了.\(c_ {i+j} +=a_i \times b_j\).时间复杂度 \(O(n*m)\) (FFT版可以做到 \(O((n+m)\log (n+m) ...
- Cobalt Strike简单使用(9,29第十五天)
本文转自:https://www.cnblogs.com/yuanshu/p/11616657.html 一.介绍: 后渗透测试工具,基于Java开发,适用于团队间协同作战,简称“CS”. CS分为客 ...
- P 1023 组个最小数
转跳点:
- comm
comm [- 123 ] file1 file2 说明:该命令是对两个已经排好序的文件进行比较.其中file1和file2是已排序的文件.comm读取这两个文件,然后生成三列输出:仅在file1中出 ...
- CTF-域渗透--靶场夺旗
开门见山 1. 扫描靶场ip 192.168.1.106 2. 扫描靶场开放端口 3. 扫描靶场全部信息 4. 探测靶场敏感信息 5. 对一些特殊的端口进行nc探测 6. 为了绕过对应命令执行限制,可 ...