利用不定长的结构体发送socket数据
2011-08-02 17:38
357 查看
//Server端代码
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<sys/types.h>
#include<netinet/in.h>
#include<sys/socket.h>
#include<unistd.h>
//使用不定长的结构体发送数据的关键在于:结构体变量必须分配到堆中,而不是栈中
//即只能用malloc或者new来给结构体分配空间
typedef struct Node
{
int nodeSize;
int bufSize;
char buf[0]; //用0字节表示该结构体不定长
} Node;
int main()
{
int sockfd,new_fd;
struct sockaddr_in server_addr;
struct sockaddr_in client_addr;
if((sockfd = socket(AF_INET,SOCK_STREAM,0)) == -1)
{
printf("socket error!\n");
exit(1);
}
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(5050);
server_addr.sin_addr.s_addr = INADDR_ANY;
bzero(&(server_addr.sin_zero),8);
if(bind(sockfd,(struct sockaddr *)&server_addr,sizeof(server_addr)) == -1)
{
printf("bind error!\n");
exit(1);
}
if(listen(sockfd,100) == -1)
{
printf("listen error!\n");
exit(1);
}
printf("Server is listening:\n");
while(1)
{
int sin_size = sizeof(struct sockaddr_in);
if((new_fd = accept(sockfd,(struct sockaddr *)&client_addr,(socklen_t *)&sin_size)) == -1)
{
printf("accept error!\n");
exit(1);
}
int recvSize = 0;//data total length
if(recv(new_fd,(char *)&recvSize,sizeof(recvSize),0) == -1)
{
printf("recv error!\n");
exit(1);
}
int leftSize = sizeof(char) * (recvSize - sizeof(int));
char *dataBuf = (char *)malloc(leftSize);
memset(dataBuf,0,leftSize);
if(recv(new_fd,dataBuf,leftSize,0) == -1)
{
printf("recv error!\n");
exit(1);
}
close(new_fd);
Node *p = (Node *)malloc(sizeof(char) * recvSize);
p->nodeSize = recvSize;
memcpy((char *)(&p->bufSize),dataBuf,leftSize);
printf("nodeSize = %d\n",p->nodeSize);
printf("bufSize = %d\n",p->bufSize);
printf("buf = %s\n",p->buf);
}
return 0;
}
//Client端代码
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<sys/types.h>
#include<netinet/in.h>
#include<sys/socket.h>
#include<unistd.h>
//使用不定长的结构体发送数据的关键在于:结构体变量必须分配到堆中,而不是栈中
//即只能用malloc或者new来给结构体分配空间
typedef struct Node
{
int nodeSize;
int bufSize;
char buf[0]; //用0字节表示该结构体不定长
} Node;
int main()
{
int sockfd,new_fd;
struct sockaddr_in server_addr;
struct sockaddr_in client_addr;
if((sockfd = socket(AF_INET,SOCK_STREAM,0)) == -1)
{
printf("socket error!\n");
exit(1);
}
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(5050);
server_addr.sin_addr.s_addr = INADDR_ANY;
bzero(&(server_addr.sin_zero),8);
if(bind(sockfd,(struct sockaddr *)&server_addr,sizeof(server_addr)) == -1)
{
printf("bind error!\n");
exit(1);
}
if(listen(sockfd,100) == -1)
{
printf("listen error!\n");
exit(1);
}
printf("Server is listening:\n");
while(1)
{
int sin_size = sizeof(struct sockaddr_in);
if((new_fd = accept(sockfd,(struct sockaddr *)&client_addr,(socklen_t *)&sin_size)) == -1)
{
printf("accept error!\n");
exit(1);
}
int recvSize = 0;//data total length
if(recv(new_fd,(char *)&recvSize,sizeof(recvSize),0) == -1)
{
printf("recv error!\n");
exit(1);
}
int leftSize = sizeof(char) * (recvSize - sizeof(int));
char *dataBuf = (char *)malloc(leftSize);
memset(dataBuf,0,leftSize);
if(recv(new_fd,dataBuf,leftSize,0) == -1)
{
printf("recv error!\n");
exit(1);
}
close(new_fd);
Node *p = (Node *)malloc(sizeof(char) * recvSize);
p->nodeSize = recvSize;
memcpy((char *)(&p->bufSize),dataBuf,leftSize);
printf("nodeSize = %d\n",p->nodeSize);
printf("bufSize = %d\n",p->bufSize);
printf("buf = %s\n",p->buf);
}
return 0;
}
//Client端代码
#include<stdio.h> #include<stdlib.h> #include<string.h> #include<sys/types.h> #include<arpa/inet.h> #include<netinet/in.h> #include<sys/socket.h> #include<unistd.h> typedef struct Node { int nodeSize; int bufSize; char buf[0]; } Node; int main() { int sockfd,new_fd; struct sockaddr_in server_addr; if((sockfd = socket(AF_INET,SOCK_STREAM,0)) == -1) { printf("socket error!\n"); exit(1); } server_addr.sin_family = AF_INET; server_addr.sin_port = htons(5050); server_addr.sin_addr.s_addr = inet_addr("127.0.0.1"); bzero(&(server_addr.sin_zero),8); if(connect(sockfd,(struct sockaddr *)&server_addr,sizeof(server_addr)) == -1) { printf("connect error!\n"); exit(1); } printf("Client is connecting\n"); const char *tmp = "this is a test!"; int tmpLen = strlen(tmp); Node *dataBuf = (Node *)malloc(sizeof(Node) + tmpLen + 1); dataBuf->nodeSize = sizeof(Node) + tmpLen + 1; dataBuf->bufSize = tmpLen; memset(dataBuf->buf,0,tmpLen + 1); memcpy(dataBuf->buf,tmp,tmpLen + 1); printf("nodeSize = %d\n",dataBuf->nodeSize); printf("bufSize = %d\n",dataBuf->bufSize); printf("buf = %s\n",dataBuf->buf); if(send(sockfd,(char *)dataBuf,dataBuf->nodeSize,0) == -1) { printf("send error!\n"); exit(1); } close(sockfd); return 0; }
相关文章推荐
- 利用不定长的结构体发送socket数据
- C#网络Socket的数据发送与接收处理(利用异步)的模板(模式)
- c#中利用结构体进行socket传输数据
- android 利用socket 发送Json数据demo
- android 利用socket 发送和解析Json数据
- TCP socket发送整形数据(数组,结构体)
- [C#参考]利用Socket连续发送数据
- PHP利用socket模拟post之fsockopen发送数据
- C#网络Socket的数据发送与接收处理(利用异步)的模板(模式)
- 利用socket安全发送一段数据
- 在android的同一个wifi局域网下,利用socket与多个手机进行数据的收发
- 利用结构体来传递一组数据
- [Linux]非阻塞模式下socket发送数据
- Java网络编程从入门到精通(13):使用Socket类接收和发送数据
- Socket一对多。。利用Socket发送命令给客户机让其执行关机命令 分类: .NET 2010-10-22 18:00 1768人阅读 评论(0) 收藏
- QTcpSocket的连续发送数据和连续接收数据
- (原)关于udp的socket发送数据耗时的问题探讨
- mfc socket发送和接收数据和文件
- 异步SOCKET编程-发送和接收数据
- 利用python调用elasticsearch-api来分析数据并作图进行日报邮件发送