c语言socket编程代码例子

c语言socket编程代码例子socket_client客户端代码#include<sys/types.h>#include<sys/socket.h>#include<stdio.h>#include<string.h>#include<error.h>#include<netinet/in.h>intmain(){//1.创建socket,socket()函数intsockfd=0;sockfd=sock.

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

 socket_client客户端代码

#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <string.h>
#include <error.h>
#include <netinet/in.h>
  
int main()
{
//1.创建socket,socket()函数  
int sockfd=0;
sockfd = socket(AF_INET,SOCK_STREAM,0);
if(sockfd ==-1 ){
printf("创建失败:%d");
perror("socket");
}
else printf("创建成功:sockfd=%d\n",sockfd);
   
//2.初始化ip、端口,connect()函数    
struct sockaddr_in addr ;//创建地址类型,结构体    
memset(&addr,0,sizeof(addr));   //结构体置0
addr.sin_family=AF_INET;  //使用ipv4地址    
addr.sin_addr.s_addr=inet_addr("127.0.0.1");  //转换为无符号长整数型数。    
addr.sin_port=htons(5005);  //绑定端口,将主机的无符号短整形数转换成网络字节顺序。    
if (connect(sockfd,(struct sockaddr*)&addr,sizeof(addr))==0) {
printf("已连接服务器!\n");
}
else { perror("connect");     }
    
//3.与服务端通信,发送报文    
int iret;
char buffer[1024];
memset(buffer,0,sizeof(buffer));  //清空buffer
strcpy(buffer,"发送第一个报文");
if ((iret=send(sockfd,buffer,strlen(buffer),0))<=0)  //向服务器发送报文;    
{
perror("send");
}
else {
printf("发送了一个%d字节的数据\n",iret);
}
   
//3.接收报文
char buffer1[1024];
memset(buffer1,0,strlen(buffer1)); //清空buffer
if((iret=recv(sockfd,buffer1,sizeof(buffer1),0))<=0)   //接收服务的发送的报文
{
perror("recv");
}
else{printf("接收:%s\n",buffer1);}

    
sleep(30);//程序睡眠30秒,以便其他客户端连接服务器,观察现象    
 
//1.释放资源
close(sockfd);    
    
    
    
return 0; 
}

Jetbrains全家桶1年46,售后保障稳定

 socket_server服务端代码

#include <sys/types.h>
#include<openssl/buffer.h>
#include <sys/socket.h>
#include <stdio.h>
#include <string.h>
#include <error.h>
#include <netinet/in.h>
int main()
{
int sockfd;

//1.创建socket,socket()函数
sockfd = socket(AF_INET,SOCK_STREAM,0);
if(sockfd ==-1 ){
printf("创建失败:");
perror("socket");
}
else printf("创建成功:sockfd=%d\n",sockfd);
 
 
//2.绑定ip、端口,bind()函数
struct sockaddr_in addr ;//创建地址类型,结构体
memset(&addr,0,sizeof(addr));   //结构体置0
addr.sin_family=AF_INET;  //使用ipv4地址	
addr.sin_addr.s_addr=inet_addr("127.0.0.1");  //转换为无符号长整数型数。
addr.sin_port=htons(5005);  //绑定端口,将主机的无符号短整形数转换成网络字节顺序。
bind(sockfd,(struct sockaddr*)&addr,sizeof(addr));
/* sockaddr_in 结构体,然后再强制转换为 sockaddr 类型,sockaddr 和 sockaddr_in 的长度相同,都是16字节,只是将IP地址和端口号合并到一起,用一个成员 sa_data 表示。要想给 sa_data 赋值,必须同时指明IP地址和端口号,例如”127.0.0.1:80“,遗憾的是,没有相关函数将这个字符串转换成需要的形式,也就很难给 sockaddr 类型的变量赋值,所以使用 sockaddr_in 来代替。这两个结构体的长度相同,强制转换类型时不会丢失字节,也没有多余的字节。
可以认为,sockaddr 是一种通用的结构体,可以用来保存多种类型的IP地址和端口号,而 sockaddr_in 是专门用来保存 IPv4 地址的结构体
*/ 
 
 
 
while(1)//持续监听
{ 
 
//3.把socket设置为监听模式listen()函数
if(listen(sockfd,3)!=0){
perror("linsten");
close(sockfd);
}
else { printf("正在监听...\n");  } 
 
 
//4.接收客户端连接accept()函数
/*accept() 返回一个新的套接字来和客户端通信,addr 保存了客户端的IP地址和端口号,
,而 sock 是服务器端的套接字,大家注意区分。后面和客户端通信时,要使用这个新生成的套接字,而不是原来服务器端的套接字。 
*/
struct sockaddr_in client_addr ;//创建地址类型,结构体,接收客户端地址
int clientfd;
socklen_t socklen=sizeof(client_addr);
if((clientfd=accept(sockfd,(struct sockaddr*)&client_addr,&socklen))!=-1 ) //指定服务端fd,接收客户端fd和ip,需要转换为accept要求格式。 
{
printf("clientfd%d:连接成功\n",clientfd);
}
else {perror("accept");}
 

//5.与客户的通信,接收报文
char buffer[1024]; 
int iret;
memset(buffer,0,sizeof(buffer)); 
if ((iret=recv(clientfd,buffer,sizeof(buffer),0))== -1)   //接收客户端的报文
{
perror("recv");
}
else if(iret==0)
{
printf("%d断开连接!\n",clientfd);
}
else {printf("接收报文:%s\n",buffer);}

//5.回复报文
memset(buffer,0,sizeof(buffer)); 
strcpy(buffer,"ok");
if((iret=send(clientfd,buffer,strlen(buffer),0))<=0) //发送报文给客户端
{
perror("send");
}
else{printf("发送报文:%s\n",buffer);}
 
//6.释放资源 
close("sockfd");close(clientfd) ;
 
 
 
}//while 循环
 
 
 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/207129.html原文链接:https://javaforall.net

(0)
上一篇 2025年8月2日 下午5:22
下一篇 2025年8月2日 下午6:01


相关推荐

  • Python 相对路径问题:“No such file or directory“,原因及解决方法

    Python 相对路径问题:“No such file or directory“,原因及解决方法如果你取相对路径不是在主文件里,可能就会有相对路径问题:”Nosuchfileordirectory”。因为python的相对路径,相对的都是主文件。main.py是主文件。conf.py里引用config.txt用相对路径。如果用.或…相对的是main.py,所以用”./config.txt”,相对于main.py是同一个目录下。.指当前文件所在的文件夹,…指当前文件的上一级目录。

    2022年5月7日
    47
  • 定点数与浮点数区别

    定点数与浮点数区别最近做 HDR 时 经常要用 NV 提供的 16 位纹理 它的说明书 16 位能达到 24 位的精度 就很奇怪 一直搞不懂浮点数的精度怎么算的 今天认真看了一下 IEEEfloatpoi 的标准 终于明白是什么了 1

    2026年2月11日
    7
  • nmf java_NMF & pLSA[通俗易懂]

    nmf java_NMF & pLSA[通俗易懂]今天在围脖中看到自动化所刘康的围脖中给了一个关于NMF和pLSA对比分析的链接http://ezcodesample.com/plsaidiots/NMFPLSA.html,大体读了一下,下面用中文对文中的思想重新解释,版权归原作者AndrewPolar。一、名词解释(1)NMF,nonnegativematrixfactorization,直观理解即非负矩阵分解,通常用于矩阵填充,推荐系…

    2022年6月29日
    40
  • 「2017 山东一轮集训 Day5」苹果树「建议收藏」

    「2017 山东一轮集训 Day5」苹果树「建议收藏」「2017 山东一轮集训 Day5」苹果树

    2022年4月21日
    55
  • OCR-CTPN 文字检测

    OCR-CTPN 文字检测文本检测和一般目标检测的不同 文本线是一个 sequence 字符 字符的一部分 多字符组成的一个 sequence 而不是一般目标检测中只有一个独立的目标 这既是优势 也是难点 优势体现在同一文本线上不同字符可以互相利用上下文 可以用 sequence 的方法比如 RNN 来表示 难点体现在要检测出一个完整的文本线 同一文本线上不同字符可能差异大 距离远 要作为一个整体检测出来难度比单个目标更大 因此 作者认为预测文本的竖直位置 文本 boundingbox 的上下边界 比水平位置 文本 boundingbox 的

    2026年3月16日
    2
  • vue后台管理系统流程(面试必选)

    vue后台管理系统流程(面试必选)口述 vue 后台管理系统流程 面试可用 后台页面的权限验证与安全性是非常重要的 可以说是一个后台项目一开始就必须考虑和搭建的基础核心功能我们前端所要做的是 不同的权限对应着不同的路由 同时侧边栏也需要根据不同的权限 异步生成 技术栈主要有 vue vue router vuex axios vue cli3 x 没有 webpack config js 配置文件 取而代之的是 vue c

    2026年3月17日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号