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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • oracle协议适配器错误tns,ORA-12560: TNS: 协议适配器错误 常见原因

    oracle协议适配器错误tns,ORA-12560: TNS: 协议适配器错误 常见原因或者报以下错误(Listenerrefusedtheconnectionwiththefollowingerror:ORA-12514,TNS:listenerdoesnotcurrentlyknowofservicerequestedinconnectdescriptorTheConnectiondescriptorusedbythecli…

    2022年6月18日
    36
  • 解决新版chrome跨域问题:cookie丢失以及samesite属性问题「建议收藏」

    解决新版chrome跨域问题:cookie丢失以及samesite属性问题「建议收藏」最近在使用前后端分离开发的时候,遇到了一个诡异的问题,无论如何设置跨域,同一个页面获取到的session始终不一致。发现问题:登录界面前后端分离,ajax提交登录时出错验证码接口和登录接口的session不一致(跨域问题)在网上搜索跨域问题,重新设置,问题依旧错因排除:ajax允许cookie(已经设置xhrFields:{withCredentials:true})springboot尝试设置了多种跨域方法(springboot解决跨域)深入分析:使用其它浏览器(fi

    2022年6月9日
    232
  • php导出excel表格_phpspreadsheet导出

    php导出excel表格_phpspreadsheet导出Spout是一个PHP库,可以快速,可扩展的方式读写电子表格文件(CSV,XLSX和ODS)。与其他文件读写器相反,它能够处理非常大的文件,同时保持内存使用率非常低。phpspreadsheet是phpexcel的下一个版本。它打破了兼容性,大大提高了代码基础质量(名称空间、PSR兼容性、使用最新的PHP语言功能等)。因为所有的努力都转移到了phpspreadsheet,phpexcel将不……………

    2022年9月17日
    0
  • golan激活码【在线破解激活】

    golan激活码【在线破解激活】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月17日
    42
  • python进阶(17)偏函数partial

    python进阶(17)偏函数partial什么是偏函数partialpython中提供一种对于函数固定属性的函数偏函数的作用把一个函数的某些参数给固定住(也就是设置默认值),返回一个新的函数偏函数的语法使用偏函数必须先导入from

    2022年7月30日
    3
  • stringutils.isnotempty可以判断null_string方法的使用

    stringutils.isnotempty可以判断null_string方法的使用StringUtils方法的操作对象是java.lang.String类型的对象,是JDK提供的String类型操作方法的补充,并且是null安全的(即如果输入参数String为null则不会抛出NullPointerException,而是做了相应处理,例如,如果输入为null则返回也是null等,具体可以查看源代码)。除了构造器,StringUtils中一共有130多个方法,并且都是stati…

    2022年10月7日
    0

发表回复

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

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