良许Linux教程网 干货合集 Linux系统socket编程详细教程

Linux系统socket编程详细教程

socket 是计算机网络中用于在节点内发送或接收数据的内部端点。具体来说,它是网络软件 (协议栈) 中这个端点的一种表示,下面和大家详细讲解一下Linux系统中server编程的详细教程。

socket简介:

socket 是计算机网络中用于在节点内发送或接收数据的内部端点。具体来说,它是网络软件 (协议栈) 中这个端点的一种表示,包含通信协议、目标地址、状态等,是系统资源的一种形式。

它在网络中所处的位置大致就是下面的黑色部分,应用层与传输层之间。

imgimg

其中的传输层就是 TCP/IP 所在的地方,而你平时通过代码编写的应用程序大多属于应用层范畴,socket 在这里起到就是连接应用层与传输层的作用。

socket 的诞生是为了应用程序能够更方便的将数据经由传输层来传输,所以它本质上就是对 TCP/IP 的运用进行了一层封装,然后应用程序直接调用 socket API 即可进行通信。那么它是如何工作的呢?它分为 2 个部分,服务端需要建立 socket 来监听指定的地址,然后等待客户端来连接。而客户端则需要建立 socket 并与服务端的 socket 地址进行连接。

server端的简单示例:

经过前面的client端的学习,我们已经知道了如何创建socket,所以接下来就是去绑定他到具体的一个端口上去。

绑定socket到一个端口上去

bind()函数可以将socket绑定一个端口上,client可以通过这个端口发起请求,端口对应的socket便会与client端的socket连接。

 #include
 #include
 #include
 #include
 #Include
 
 int main()
 {
 int socket_desc;
 struct sockaddr_in server;
 
 socket_desc = socket(AF_INET,SOCK_STREAM,0);
 if(-1==socket_desc)
 {
 perror("socket create error\n");
 exit(1);
 }
 
 //监听服务器自身
 
 server.sin_family=AF_INET;
 server.sin_port = htons(8888);
 server.sin_addr.s_addr = INADDR_ANY;
 
 //绑定到端口
 
 if(bind(socket_desc,(struct sockaddr* )&server,sizeof(server))

对于socket绑定到一个明确的端口上,我们接下来要做的就是接受这个端口下面的所有数据。。

通过上面的实现,我们可以看出一个端口只能被一个socket使用。

监听端口:

在绑定完成socket与端口之后,我们还需要去监听端口。为此,我们需要将socket设置在被监听的状态。listen()将被用来将socket设置为被监听的模式下。

listen( socket_desc, 3);

listen(int sockfd,int backlog);可以将socket处于监听的状态下

接收请求建立连接:

 #include
 #include
 #include
 #include
 
 int main()
 {
 int sock_desc,new_socket,sockaddr_size;
 struct sockaddr_in server,client;
 
 //创建socket
 sock_desc = socket(AF_INET,SOCK_STREAM,0);
 if(-1==sock_desc)
 {
 perror("cannot create socket\n");
 exit(1);
 }
 
 server.sin_family = AF_INET;
 server.sin_port = htons(8888);
 server.sin_addr.s_addr = INADDR_ANY;
 
 //绑定
 
 if(bind(sock_desc,(struct sockaddr*)&server,sizeof(server))

运行上述代码:输出:waiting for incoming connecions.

现在代码已经正常跑起来了,并且等待请求连接。在另外一个终端内,我们发起一个请求:

teltnet 127.0.0.1 8888

在当前这个终端内将会输出:

trying 127.0.0.1

connected to loaclhost。

Escape character is ;;

connection closed by foreign host

同时在之前的终端中,server会输出:

waiting for incoming connecions.

connection accepted

便可以看到,server已经正确接收了client的连接请求并建立了连接,只是没有了后续操作,主机紧接着关闭了这个链接。

连接建立之后便可以顺利地进行双方的通信,这部分的send与recv操作完全一样。

另外, 服务端获取客户端的ip地址:

由前面能够知道accept()返回的是结构体sockaddr_in ,由此很容易得知client的ip和端口信息。** **

 char * client_ip = inet_ntoa(client.sin_addr);``int` `client_port = ntohs(client.sin_port);

以上就是良许教程网为各位朋友分享的Linux系统相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多干货等着你!

137e00002230ad9f26e78-265x300

本文由 良许Linux教程网 发布,可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。
良许

作者: 良许

良许,世界500强企业Linux开发工程师,公众号【良许Linux】的作者,全网拥有超30W粉丝。个人标签:创业者,CSDN学院讲师,副业达人,流量玩家,摄影爱好者。
上一篇
下一篇

发表评论

联系我们

联系我们

公众号:良许Linux

在线咨询: QQ交谈

邮箱: yychuyu@163.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部