基於TCP的socket通信,實現加減乘除(方法一)

服務器端:

#include<stdio.h>
#include<stdlib.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<sys/un.h>
#include<sys/wait.h>
#include<errno.h>
#include<unistd.h>
#include<signal.h>
#include<netdb.h>


void sig_handler(int signo)
{
pid_t pid;
int stat;
pid=waitpid(-1,&stat,WNOHANG);
while(pid>0){
printf("child process terminated (PID:%ld)\n",(long)getpid());
pid=waitpid(-1,&stat,WNOHANG);
}
return ;
}


typedef struct {
        char s[10];
        int a;
        int b;
        char m[1024];
        }Message;


int main(int argc,char *argv[])
{
socklen_t clt_addr_len;
int listen_fd;
int com_fd;
int ret;
int result,a,b;
int s[2];
static char recv_buf[1024];
int len;
int port;
pid_t pid;
char *delim = " ";
char *p;
char *c;
struct sockaddr_in clt_addr;
struct sockaddr_in srv_addr;


//服務器端運行時要給出端口信息,該端口爲監聽端口
if(argc!=2){
printf("Usage:%s port\n",argv[0]);
return 1;
}


//獲得輸入的端口
port=atoi(argv[1]);
//設置信號處理函數,也可以使用sigaction函數
if(signal(SIGCHLD,sig_handler)<0){
perror("cannot set the signal");
return 1;
}


//創建套接字用於服務器的監聽
listen_fd=socket(PF_INET,SOCK_STREAM,0);
if(listen_fd<0){
perror("cannot create listening socket");
return 1;
}


bzero(&srv_addr,sizeof(srv_addr));
srv_addr.sin_family=AF_INET;
srv_addr.sin_addr.s_addr=htonl(INADDR_ANY);
srv_addr.sin_port=htons(port);


ret=bind(listen_fd,(struct sockaddr*)&srv_addr,sizeof(srv_addr));
if(ret==1)
{
perror("cannot bind server socket");
close(listen_fd);
return 1;
}
//監聽指定端口 ,連接一千個客戶端
ret=listen(listen_fd,1000);
if(ret==-1){
perror("cannot listen the client connect request");
return 1;
}


//對每個連接來的客戶端創建一個進程,單獨與其進行通信
//首先調用read函數讀取客戶端發送來的信息
while(1){
len=sizeof(clt_addr);
com_fd=accept(listen_fd,(struct sockaddr*)&clt_addr,&len);
if(com_fd<0){
if(errno==EINTR){
continue;
}else{
perror("cannot accept client connect request");
close(listen_fd);
return 1;
}
}
pid=fork();
if(pid<0){
perror("cannot create the child process");
close(listen_fd);
return 1;
}else if(pid==0){
while(1){
bzero(recv_buf, 1024);
read(com_fd,recv_buf,1024);
p=strtok(recv_buf,delim);
if(p)
c=p;
int i=1;
while(p=strtok(NULL,delim)){
s[i]=p;
i++;
}
a=atoi(s[1]);
        b=atoi(s[2]);
printf("接收到客戶端的信息:%s %d %d\n",c,a,b);
if(strcmp(c,"add")==0)
result=a+b;
if(strcmp(c,"sub")==0)
        result=a-b;
if(strcmp(c,"mul")==0)
        result=a*b;
if(strcmp(c,"div")==0)
        result=a/b;

printf("result=%d\n",result);
        bzero(recv_buf, 1024);
sprintf(recv_buf,"%d",result);
write(com_fd,recv_buf,strlen(recv_buf) + 1);
}
close(com_fd);
        return 0;
}
}
return 0;
}



客戶端:

#include<stdio.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<sys/un.h>
#include<netdb.h>
#include<unistd.h>


int main(int argc,char *argv[]){
int connect_fd;
int ret;
int i;
int port;
int len;
static char snd_buf[1024];
static struct sockaddr_in srv_addr;
typedef struct {
char s[10];
int a;
int b;
char m[1024];
}Message;
//客戶端運行需要給出具體的鏈接地址和端口
if(argc!=3){
printf("Usage:%s server_ip_address port\n",argv[0]);
return 1;
}

port=atoi(argv[2]);

connect_fd=socket(PF_INET,SOCK_STREAM,0);
if(connect_fd<0){
perror("cannot create communication socket");
return 1;
}
bzero(&srv_addr,sizeof(srv_addr));
srv_addr.sin_family=AF_INET;
srv_addr.sin_addr.s_addr=inet_addr(argv[1]);
srv_addr.sin_port=htons(port);
//連接指定的服務器
ret=connect(connect_fd,(struct sockaddr*)&srv_addr,sizeof(srv_addr));
if(ret==-1){
perror("cannot connect to the server");
close(connect_fd);
return 1;
}
int size = 1024;

//用戶輸入信息後,程序將輸入的信息通過套接字發送給服務器
//然後調用read函數從服務器中讀取發送來的消息
while(1){
write(STDOUT_FILENO,"請輸入需要的操作:",27);
bzero(snd_buf,size);
len=read(STDIN_FILENO,snd_buf,1024);
if(len>0){
write(connect_fd,snd_buf,strlen(snd_buf) + 1);
}
len=read(connect_fd,snd_buf,size);
if(len>0)
printf("服務器返回的結果:%s,長度爲:%d\n",snd_buf, len);
}
close(connect_fd);
return 0;
}

程序運行:

#./server 5000

#./client 192.168.1.124 5000 

IP寫你自己服務器的IP

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章