服务端connect

#include<stdio.h>  
#include<stdlib.h>  
#include<string.h>  
#include<errno.h>  
#include<sys/types.h>  
#include<sys/socket.h>  
#include<netinet/in.h>
  
#define DEFAULT_PORT 10000  
#define MAXLINE 4096 


//通信协议数组
char tcp_flag[4069];
char cmd_type[5];
char data_len[5];
int  cmd__;
int  len__;
char data[1024];




int    socket_fd, connect_fd;  
struct sockaddr_in     servaddr;  
char   buff[4096] = {0};  
char   sendBuf[4069];
int     n;  


char *cmd_tcp;
char *len_tcp;




//整型转为字符型
char *intToBytes(int num) {  
        int i;
        char *tt=(char*)malloc(sizeof(int) + 1);


        for (i = 0; i < 4; ++i) {  
            int offset = 32 - (i + 1) * 8;  
            tt[i] = (char) ((num >> offset) & 0xff); 
           // printf("%d--",tt[i]);
        }  
        return tt;  
free(tt);
tt=NULL;
    } 

//字符型转为整型
int bytesToInt(char bytes[]) {  
        int num = 0,i;  
        for (i = 0; i < 4; ++i) {  
            num <<= 8;  
            num |= (bytes[i] & 0xff);  
        }  
        return num;  
    }


//字符转换函数
void toBuff(){
cmd_tcp=(char*)malloc(sizeof(int) + 1);
len_tcp=(char*)malloc(sizeof(int) + 1);
cmd_tcp=intToBytes(cmd__);
len_tcp=intToBytes(len__);
}


//发送函数
void response_msg(){
send(connect_fd, tcp_flag, 4,0);
    send(connect_fd, cmd_tcp, 4,0);
    send(connect_fd, len_tcp, 4,0);
    send(connect_fd, data, strlen(data),0);
}

int main()  
{  
    //初始化Socket  
    if( (socket_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1 ){  
    printf("create socket error: %s(errno: %d)\n",strerror(errno),errno);  
    exit(0);  
    }  
    //初始化  
    memset(&servaddr, 0, sizeof(servaddr));  
    servaddr.sin_family = AF_INET;  
    servaddr.sin_addr.s_addr = htonl(INADDR_ANY);//IP地址设置成INADDR_ANY,让系统自动获取本机的IP地址。  
    servaddr.sin_port = htons(DEFAULT_PORT);//设置的端口为DEFAULT_PORT  
  
    //将本地地址绑定到所创建的套接字上  
    if( bind(socket_fd, (struct sockaddr*)&servaddr, sizeof(servaddr)) == -1){  
    printf("bind socket error: %s(errno: %d)\n",strerror(errno),errno);  
    exit(0);  
    }  
    //开始监听是否有客户端连接  
    if( listen(socket_fd, 10) == -1){  
    printf("listen socket error: %s(errno: %d)\n",strerror(errno),errno);  
    exit(0);  
    }  
    printf("waiting for client's request\n");  
    while(1){  
    //阻塞直到有客户端连接,不然多浪费CPU资源。  
        if( (connect_fd = accept(socket_fd, (struct sockaddr*)NULL, NULL)) == -1){  
        printf("accept socket error: %s(errno: %d)",strerror(errno),errno);  
        continue;  
    }  
    //接受客户端传过来的数据  
    n = recv(connect_fd, buff, MAXLINE, 0);  
    buff[n] = '\0';

//获取客户端传过来的数据
int k;
for(k=0; k<4; k++) tcp_flag[k] = buff[k];
for(k=4; k<8; k++) cmd_type[k-4] = buff[k];
for(k=8; k<12; k++) data_len[k-8] = buff[k];
for(k=12; k<n; k++) data[k-12] = buff[k];

    //解析数据
    cmd__ = bytesToInt(cmd_type);
    len__ = bytesToInt(data_len);

switch(cmd__){

//请求连接响应
case 0:toBuff(); //把int类型转为4字节数
      data[0]='2';//数据为 1 or 2 表示加密或不加密
          data[1]='\0';
  response_msg();//响应客户端的信息
          break;
   //断开
case 1:;break;
//xml消息响应
case 2:;break;
//json消息响应
case 3:;break;
//图片文件响应
case 4:;break;
//其他文件响应
case 5:;break;
//url响应
case 6:;break;
}

//测试数据
    // printf("cmd__-----: %d\n",cmd__);
    //printf("len__-----: %d\n",len__);
    //printf("buff--: %s\n",buff);
//测试sprintf函数
//char cmd_tcp[14],data_sec='2';
//int j;
//j=sprintf(cmd_tcp,"%c%c%c%c%d%d%d%d%d%d%d%d",buff[0],buff[1],buff[2],buff[3],buff[4],buff[5],buff[6],buff[7],buff[8],buff[9],buff[10],buff[11],buff[12]);
//j+=sprintf(cmd_tcp+j,"%c",data_sec);
//申请内存空间将int型数据命令及长度转换为字符型并存储

//响应数据为1/2;1为不加密,2为加密
    
//进行字符串拼接
    // link(tcp_flag,cmd_tcp);
    //link(tcp_flag,len_tcp);
    //link(tcp_flag,data);
    
//char aa[5]="0004";
//link(tcp_flag,aa);
//printf("testtesttest: %s\n", tcp_flag);
    //向客户端发送回应数据   
//if(!fork()){ 
    //   if((send(connect_fd, tcp_flag, 13,0)) == -1)  
    //    perror("send error");  
    //    close(connect_fd);  
    //    exit(0);  
    //  } 
    close(connect_fd);  
}
    close(socket_fd);  
}  





















评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值