C++ 如何在.c编程中在客户端和服务器之间建立sip会话
这是客户端-服务器应用程序,我想在客户端和服务器之间建立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
服务器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?