C++ 如何在.c编程中在客户端和服务器之间建立sip会话

C++ 如何在.c编程中在客户端和服务器之间建立sip会话,c++,c,C++,C,这是客户端-服务器应用程序,我想在客户端和服务器之间建立SIP(会话启动协议) 所以请任何人指导我怎么做 服务器c: #包括 #包括 #包括 #包括 #包括 #包括 #包括 #包括 #包括 #包括 #包括 #包括 #定义MYPORT 3490//用户将连接到的端口 #定义BACKLOG 10//队列将容纳多少个挂起的连接 #定义MAXDATASIZE 100 void str_服务器(int); void sigchld_处理程序(int s) { 而(waitpid(-1,NULL,WNO

这是客户端-服务器应用程序,我想在客户端和服务器之间建立SIP(会话启动协议)

所以请任何人指导我怎么做


服务器c:


#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#定义MYPORT 3490//用户将连接到的端口
#定义BACKLOG 10//队列将容纳多少个挂起的连接
#定义MAXDATASIZE 100
void str_服务器(int);
void sigchld_处理程序(int s)
{
而(waitpid(-1,NULL,WNOHANG)>0);
}
内部主(空)
{
int sockfd,numbytes,new_fd,optlen;//在sock_fd上侦听,在new_fd上新建连接
我的地址中的struct sockaddr\u;//我的地址信息
struct sockaddr_在其地址中;//连接器的地址信息
结构tcp_信息;
袜子的大小;
struct-sigaction-sa;
char buf[MAXDATASIZE];
int yes=1;
if((sockfd=socket(AF_INET,SOCK_STREAM,0))=-1){
佩罗(“插座”);
出口(1);
}
if(setsockopt(sockfd,SOL_SOCKET,SO_REUSEADDR,&yes,sizeof(int))=-1){
perror(“setsockopt”);
出口(1);
}
my\u addr.sin\u family=AF\u INET;//主机字节顺序
my_addr.sin_port=htons(MYPORT);//短,网络字节顺序
my_addr.sin_addr.s_addr=INADDR\u ANY;//自动填充我的IP
memset(我的地址sin\u zero,“\0”,我的地址sin\u zero的大小);
if(绑定(sockfd,(结构sockaddr*)&我的地址,我的地址的大小)=-1){
佩罗(“绑定”);
出口(1);
}
如果(侦听(sockfd,BACKLOG)=-1){
佩罗尔(“倾听”);
出口(1);
}
sa.sa_handler=sigchld_handler;//获取所有死进程
sigemptyset(和sa.sa_面具);
sa.sa_标志=sa_重启;
if(sigaction(SIGCHLD,&sa,NULL)=-1){
佩罗尔(“sigaction”);
出口(1);
}
while(1){//main accept()循环
sin_size=其地址的大小;
getchar();
如果((new_fd=accept(sockfd,(struct sockaddr*)及其地址\
&sin_大小)==-1){
佩罗(“接受”);
继续;
}
printf(“服务器:已从%s获得连接\n”\
inet_ntoa(他们的地址sin_addr));
如果(!fork()){//这是子进程
close(sockfd);//孩子不需要侦听器
如果((numbytes=recv(new_fd,buf,MAXDATASIZE-1,0))=-1){
perror(“recv”);
出口(1);
}
buf[numbytes]='\0';
printf(“从客户端接收:%s\n”,buf);
stru服务器(sockfd);
文件*fp=fopen(“advention.mpg”、“rb”);
//如果(!fork())
//execlp(“gedit”、“gedit”、“SIPFILE.txt”、NULL);
//系统(“popen/home/umair/Documents/CurrentData/SIPFILE.txt”);
//ShellExecute(GetDesktopWindow(),“打开”,“ls/home/umair/Documents
/CurrentData/SIPFILE.txt”,NULL,NULL,SW_SHOW);
如果(发送(新的“你好,世界!\n”,14,0)=-1)
佩罗(“发送”);
关闭(新的_fd);
出口(0);
}
close(new_fd);//父级不需要此
}
返回0;
}
void str_服务器(int sock)
{ 
char-buf[1025];
const char*filename=“test.text”;
FILE*FILE=fopen(文件名,“rb”);
如果(!文件)
{
printf(“无法打开文件进行读取”);
返回;
}
而(!feof(文件))
{ 
int rval=fread(buf,1,sizeof(buf),file);
if(rval<1)
{
printf(“无法从文件中读取”);
fclose(文件);
返回;
}
int off=0;
做
{
int sent=send(sock和buf[off],rval-off,0);
如果(发送<1)
{
//如果插座未阻塞,则检查
//WSAEWOULDBLOCK/EAGAIN的套接字错误
//(取决于平台)如果为真,则
//使用select()等待一小段时间
//是时候看看套接字是否可写了
//在传输失败之前。。。
printf(“无法写入套接字”);
fclose(文件);
返回;
}
关闭+=已发送;
}
while(off

//客户c:


#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#定义端口3490//端口客户端将连接到
#定义MAXDATASIZE 100//一次可获取的最大字节数
void RecvFile(int,const char*);
文件*文件名;
int main(int argc,char*argv[])
{
int sockfd,numbytes,optlen;
char buf[MAXDATASIZE];
字符*消息;
结构宿主*he;
结构tcp_信息;
struct sockaddr_在其地址中;//连接器的地址信息
如果(argc!=2){
fprintf(stderr,“用法:客户端主机名\n”);
出口(1);
}
if((he=gethostbyname(argv[1]))==NULL){//获取主机信息
herror(“gethostbyname”);
出口(1);
}
if((sockfd=socket(AF_INET,SOCK_STREAM,0))=-1){
佩罗(“插座”);
出口(1);
}
它们的\u addr.sin\u family=AF\u INET;//主机字节顺序
它们的_addr.sin_port=htons(port);//短,网络字节顺序
他们的地址sin\u addr=*((地址中的结构)he->h\u addr);
memset(他们的地址sin\u zero,“\0”,他们的地址sin\u zero的大小);
如果(连接(sockfd,(结构sockaddr*)及其地址,
其地址的大小)=-1){
perror(“连接”);
出口(1);
}
printf(“连接成功\n”);
/*如果(发送(sockfd,“你好,世界!\n”,14,0)=-1)
佩罗(“发送”);
printf(“发送成功\n”);
*/    
message=“GET/?st=1 HTTP/1.1\r\n主机:www.msn.com\r\n\r\n”;
如果(发送(sockfd,message,strlen(message),0)<0)
{
看跌期权(“发送失败”);
返回1;
}
puts(“数据发送”);
RecvFile(sockfd,消息);
optlen=sizeof(信息);
如果((numbytes=recv(sockfd,buf,MAXDATASIZE-1,0))=-1){
perror(“recv”);
出口(1);
}
buf[numbytes]='\0';
printf(“收到:%s\n”,buf);
关闭(sockfd);
返回0;
}
void RecvFile(int sock,const char*文件名)
{ 
int-rval;
字符buf[0x1000];
FILE*FILE=fopen(文件名,“wb”);
如果(!文件)
{
printf(“C
#include  <stdio.h>
#include  <stdlib.h>
#include  <unistd.h>
#include  <errno.h>
#include  <string.h>
#include  <sys/types.h>
#include  <sys/socket.h>
#include  <netinet/in.h>
#include  <arpa/inet.h>
#include  <sys/wait.h> 
#include  <signal.h>
#include <netinet/tcp.h>

#define MYPORT 3490 // the port users will be connecting to
#define BACKLOG 10    // how many pending connections queue will hold
#define MAXDATASIZE 100

void str_server(int); 

void sigchld_handler(int s)
{
 while(waitpid(-1, NULL, WNOHANG) > 0);
}
int main(void)
{
 int sockfd, numbytes,new_fd, optlen; // listen on sock_fd, new connection on new_fd
 struct sockaddr_in my_addr; // my address information
 struct sockaddr_in their_addr; // connector's address information
 struct tcp_info info;
 socklen_t sin_size;
 struct sigaction sa;
 char buf[MAXDATASIZE];
 int yes=1;
 if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
     perror("socket");
     exit(1);
 }
 if (setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &yes, sizeof(int)) == -1) {
     perror("setsockopt");
     exit(1);
 }
 my_addr.sin_family = AF_INET;         // host byte order
 my_addr.sin_port = htons(MYPORT);     // short, network byte order
 my_addr.sin_addr.s_addr = INADDR_ANY; // automatically fill with my IP
 memset(my_addr.sin_zero, '\0', sizeof my_addr.sin_zero);
 if (bind(sockfd, (struct sockaddr *)&my_addr, sizeof my_addr) == -1) {
     perror("bind");
     exit(1);
 }
 if (listen(sockfd, BACKLOG) == -1) {
     perror("listen");
     exit(1);
 }
 sa.sa_handler = sigchld_handler; // reap all dead processes
 sigemptyset(&sa.sa_mask);
 sa.sa_flags = SA_RESTART;
 if (sigaction(SIGCHLD, &sa, NULL) == -1) {
     perror("sigaction");
     exit(1);
 }
 while(1) { // main accept() loop
     sin_size = sizeof their_addr;
     getchar();
     if ((new_fd = accept(sockfd, (struct sockaddr *)&their_addr, \
             &sin_size)) == -1) {
         perror("accept");
         continue;
     }
     printf("server: got connection from %s\n", \
         inet_ntoa(their_addr.sin_addr));

     if (!fork()) { // this is the child process
         close(sockfd); // child doesn't need the listener
         if ((numbytes=recv(new_fd, buf, MAXDATASIZE-1, 0)) == -1) {
            perror("recv");
            exit(1);
        }
        buf[numbytes] = '\0';
        printf("Received From Client: %s\n",buf);

 str_server(sockfd);
 FILE *fp = fopen( "adventure.mpg", "rb" );
 //if(!fork())
 // execlp("gedit", "gedit", "SIPFILE.txt", NULL);
            //system("popen /home/umair/Documents/CurrentData/SIPFILE.txt");
     //ShellExecute(GetDesktopWindow(), "open","ls /home/umair/Documents 

            /CurrentData/SIPFILE.txt",NULL, NULL, SW_SHOW);
         if (send(new_fd, "Hello, world!\n", 14, 0) == -1)
             perror("send");
         close(new_fd);
         exit(0);
     }
     close(new_fd); // parent doesn't need this

 }
 return 0;
 }

void str_server(int sock) 
{ 
 char buf[1025]; 
 const char* filename = "test.text"; 
 FILE *file = fopen(filename, "rb"); 
 if (!file)
{
    printf("Can't open file for reading"); 
    return;
}
while (!feof(file)) 
{ 
    int rval = fread(buf, 1, sizeof(buf), file); 
    if (rval < 1)
    {
        printf("Can't read from file");
        fclose(file);
        return;
    }

    int off = 0;
    do
    {
        int sent = send(sock, &buf[off], rval - off, 0);
        if (sent < 1)
        {
            // if the socket is non-blocking, then check
            // the socket error for WSAEWOULDBLOCK/EAGAIN
            // (depending on platform) and if true then
            // use select() to wait for a small period of
            // time to see if the socket becomes writable
            // again before failing the transfer...

            printf("Can't write to socket");
            fclose(file);
            return;
        }

        off += sent;
    }
    while (off < rval);
} 

fclose(file);
}
#include  <stdio.h>
#include  <stdlib.h>
#include  <unistd.h>
#include  <errno.h>
#include  <string.h>
#include  <netdb.h>
#include  <sys/types.h>
#include  <netinet/in.h>
#include  <sys/socket.h>
#include <netinet/tcp.h>
#define PORT 3490 // the port client will be connecting to
#define MAXDATASIZE 100 // max number of bytes we can get at once

void RecvFile(int , const char* );
FILE *filename;

int main(int argc, char *argv[])
{
 int sockfd, numbytes, optlen;
 char buf[MAXDATASIZE];
 char *message;
 struct hostent *he;
 struct tcp_info info;
 struct sockaddr_in their_addr; // connector's address information
 if (argc != 2) {
     fprintf(stderr,"usage: client hostname\n");
     exit(1);
 }
if ((he=gethostbyname(argv[1])) == NULL) {   // get the host info
     herror("gethostbyname");

     exit(1);
 }
 if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
     perror("socket");
     exit(1);
 }
 their_addr.sin_family = AF_INET;    // host byte order
 their_addr.sin_port = htons(PORT); // short, network byte order
 their_addr.sin_addr = *((struct in_addr *)he->h_addr);
 memset(their_addr.sin_zero, '\0', sizeof their_addr.sin_zero);
 if (connect(sockfd, (struct sockaddr *)&their_addr,
                                       sizeof their_addr) == -1) {
     perror("connect");
     exit(1);
 }
 printf("connect successfull\n");
/* if (send(sockfd, "Hello, world!\n", 14, 0) == -1)
     perror("send");
 printf("send successfull\n");
*/    
 message = "GET /?st=1 HTTP/1.1\r\nHost: www.msn.com\r\n\r\n";
if( send(sockfd , message , strlen(message) , 0) < 0)
{
    puts("Send failed");
    return 1;
}
puts("Data Send\n");
  RecvFile(sockfd , message);

 optlen = sizeof(info);
 if ((numbytes=recv(sockfd, buf, MAXDATASIZE-1, 0)) == -1) {
     perror("recv");
     exit(1);
 }
 buf[numbytes] = '\0';
 printf("Received: %s\n",buf);
 close(sockfd);

 return 0;
 }


void RecvFile(int sock, const char* filename) 
{ 
int rval; 
char buf[0x1000]; 
FILE *file = fopen(filename, "wb"); 
if (!file)
{
    printf("Can't open file for writing");
    return;
}

do
{
    rval = recv(sock, buf, sizeof(buf), 0);
    if (rval < 0)
    {
        // if the socket is non-blocking, then check
        // the socket error for WSAEWOULDBLOCK/EAGAIN
        // (depending on platform) and if true then
        // use select() to wait for a small period of
        // time to see if the socket becomes readable
        // again before failing the transfer...

        printf("Can't read from socket");
        fclose(file);
        return;
    }

    if (rval == 0)
        break;

    int off = 0;
    do
    {
        int written = fwrite(&buf[off], 1, rval - off, file);
        if (written < 1)
        {
            printf("Can't write to file");
            fclose(file);
            return;
        }

        off += written;
    }   
    while (off < rval);
} 
while (!feof(file)); 
fclose(file); 
}

Any Suggestion?