大数运算+web服务器

//http.h
#pragma once                                                                   
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<sys/sendfile.h>
#include<sys/stat.h>
#include<sys/epoll.h>
#include<unistd.h>
#include<fcntl.h>
#include<netinet/in.h>
#include<arpa/inet.h>
#include<assert.h>
#include<pthread.h>
#include<errno.h>
#define _DEF_PAGE_ "index.html"
#define _SIZE_ 1024
typedef struct bf
{
    char _buf[_SIZE_];
    int _fd;
    int _cgi;
    char _method[_SIZE_/2];
    char _path[_SIZE_];
    union
    {
        char* _query_string;
        int _st_size;
    };
    int _err;

}bf_t,*bf_p;
void printLog(const char* const str,const char* const fun,int line);
void usage(const char*  const  proc);
int startup(char* ip,int port);
void response_err(bf_p bf,int eno);
void echo_error(bf_p bf,int eno);
int get_line(int sock,char* buf,int size);
void clear_head(int sock);
void execute_cgi(bf_p bf);
void echo_html(bf_p bf);
void accept_request(void* ptr);       
//http.c
#include"http.h"                                                                
void printLog(const char* const str,const char* const fun,int line)
{
    printf("%s:%s:%d\n",str,fun,line);
}
void usage(const char*  const  proc)
{ 
    assert(proc); 
    printLog(proc,__FUNCTION__,__LINE__);
} 
int startup(char* ip,int port) 
{     
    assert(ip);
    int sock=socket(AF_INET,SOCK_STREAM,0);
    if(sock<0)
    {
        printLog(strerror(errno),__FUNCTION__,__LINE__);
        exit(1);
    } 
    int opt=1;
    setsockopt(sock,SOL_SOCKET,SO_REUSEADDR,&opt,sizeof(opt));
    struct sockaddr_in local; 
    local.sin_family=AF_INET;
    local.sin_port=htons(port);
    if(strncmp(ip,"any",3)==0) 
    { 
        local.sin_addr.s_addr= INADDR_ANY;
    }
    else
    {
        local.sin_addr.s_addr=inet_addr(ip);
    }
    if(bind(sock,(struct sockaddr*)&local,sizeof(local))<0)
    {
        printLog(strerror(errno),__FUNCTION__,__LINE__);
        exit(1);
    }
    if(listen(sock,5)<0)
    {
        printLog(strerror(errno),__FUNCTION__,__LINE__);
        exit(1);
    }
    return sock;
}
void response_err(bf_p bf,int eno)
{
    char state_line[_SIZE_];
    char err_des[30];//error description
    memset(state_line,‘\0‘,sizeof(state_line));
    memset(err_des,‘\0‘,sizeof(err_des));
    switch(eno)
    {          
        case 301:
            strcpy(err_des,"Removed");
            break;
        case 404:
            strcpy(err_des,"Not Found");
            break;
        case 403:
            strcpy(err_des,"Forbid");
            break;
        case 500:
            strcpy(err_des,"Inner Error");
            break;
        case 501:
            strcpy(err_des,"Not execute");
            break;
        default:
            break;
    }
    sprintf(state_line,"HTTP/1.0 %d %s\r\n\r\n",eno,err_des);
    //printf("state_line:%s\n",state_line);
    strcpy(bf->_buf,state_line);
}
void echo_error(bf_p bf,int eno)
{
    switch(eno)
    {                                      
        case 301:
            response_err(bf,eno);
            break;
        case 404:
            response_err(bf,eno);
            break;
        case 403:
            response_err(bf,eno);
            break;
        case 500:
            response_err(bf,eno);
            break;
        case 501:
            response_err(bf,eno);
            break;
        default:
            break;
    }
    return;
}
int get_line(int sock,char* buf,int size)
{
    assert(buf);
    int i=0;
    ssize_t _s=-1;
    char ch=‘\0‘;           
//  printf("getLine");
    while(i<size-1&&ch!=‘\n‘)
    {
        _s=recv(sock,&ch,1,0);
        if(_s)
        {
            if(ch==‘\r‘)
            {
                if((_s=recv(sock,&ch,1,MSG_PEEK)))
                {
                    if(_s>0&&ch==‘\n‘)
                        recv(sock,&ch,1,0);
                }
            }
            buf[i++]=ch;
        }
        else
        {
            buf[i++]=‘\n‘;
            break;
        }
    }
//  printf("endddddddddddd");
    buf[i]=‘\0‘;
    return i;
}                        
void clear_head(int sock)
{
    char buf[_SIZE_];
    buf[0]=‘\0‘;
    ssize_t _s=1;
    while(_s>0&&strcmp(buf,"\n")!=0)
    {
        _s=get_line(sock,buf,sizeof(buf));
    }
}

void execute_cgi(bf_p bf)
{
    int content_len=0;//post method content-length
    ssize_t _s=-1;
    char buf[_SIZE_];
    char method_env[30];
    char query_env[_SIZE_];
    char content_len_env[30];
    memset(buf,‘\0‘,sizeof(buf));
    memset(method_env,‘\0‘,sizeof(method_env));
    memset(query_env,‘\0‘,sizeof(query_env));
    memset(content_len_env,‘\0‘,sizeof(content_len_env));
    //if method=get,query_string not null,if method=post,query_string is null
    sprintf(method_env,"REQUEST_METHOD=%s",bf->_method);
    putenv(method_env);
    //printf("method:%s,path:%s,query_string:%s\n",method,path,query_string);
    if(strcasecmp(bf->_method,"GET")==0)
    {
        sprintf(query_env,"QUERY_STRING=%s",bf->_query_string);
        putenv(query_env);
    }
    else
    {
        while((_s=get_line(bf->_fd,buf,sizeof(buf)))>1)
        {
            if(strncasecmp(buf,"Content-Length:",15)==0)
            {
                //printf("length::::::::::%s\n",buf);
                content_len=atoi(buf+15);
            //  break;//not break!!!!!!!!!!!!!!!
            }
        }
        //printf("Content-Length:%d\n",content_len);
        sprintf(content_len_env,"CONTENT_LENGTH=%d",content_len);
        putenv(content_len_env);
    }
    //printf("ready env\n");
    //ready
    pid_t id;
    int in_fds[2];
    int out_fds[2];             
   if(pipe(in_fds)<0)
    {
        printLog(strerror(errno),__FUNCTION__,__LINE__);
        exit(1);
    }
    if(pipe(out_fds)<0) 
    {
        printLog(strerror(errno),__FUNCTION__,__LINE__);
        exit(1);
    }
//  printf("exxxxxxxxxxxxxxx");
    if((id=fork())<0)
    {
        printLog(strerror(errno),__FUNCTION__,__LINE__);
        exit(1);
    }
    else if(id==0)//child
    {
        close(in_fds[1]);
        close(out_fds[0]);
        dup2(in_fds[0],0);
        dup2(out_fds[1],1);
        execl(bf->_path,bf->_path,NULL);
            
        close(in_fds[0]);
        close(out_fds[1]);                  
    }
    else//father
    {
        close(in_fds[0]);
        close(out_fds[1]);
        char vals[1024];
        memset(vals,‘\0‘,sizeof(vals));
        ssize_t _s=-1;
        int index=0;
        char ch=‘0‘;
        if(strcasecmp(bf->_method,"POST")==0)
        {
            while(index<content_len&&read(bf->_fd,&ch,1)>0)
            {   
                vals[index++]=ch;
            }
        }
    //  printf("%s\n",vals);
        write(in_fds[1],vals,strlen(vals));
    //  printf("ffffffffffff");
        memset(bf->_buf,‘\0‘,sizeof(bf->_buf));
        char* status_line="HTTP/1.0 200 ok\r\n\r\n";
        sprintf(bf->_buf,status_line,strlen(status_line));
//      printf("response\n");
        int i=strlen(bf->_buf);
        while(read(out_fds[0],&ch,1)>0)                                                                                                                                                       
        {
            bf->_buf[i++]=ch;
        }
        bf->_buf[i]=‘\0‘;
        close(in_fds[1]);
        close(out_fds[0]);
        waitpid(id);
    }
}
void echo_html(bf_p bf)
{
    char* status_line="HTTP/1.0  200 ok\r\n\r\n";
    sprintf(bf->_buf,status_line,strlen(status_line));
    //printf("%s!!!!!!!!!!!!!!!!\n",bf->_buf);
}

void accept_request(void* ptr)
{
    bf_p bf=(bf_p)ptr;
    bf->_err=0;
    int ret=-1;
    int i=0,j=0;
    char url[_SIZE_];
    memset(bf->_method,‘\0‘,sizeof(bf->_method));
    memset(bf->_buf,‘\0‘,sizeof(bf->_buf));
    memset(bf->_path,‘\0‘,sizeof(bf->_path));          
    memset(url,‘\0‘,sizeof(url));

    if(get_line(bf->_fd,bf->_buf,sizeof(bf->_buf))==0)
    {
        printLog("errno",__FUNCTION__,__LINE__);
        return;
    }
    i=j=0;
    while(‘\0‘!=bf->_buf[i]&&!isspace(bf->_buf[i])&&i<strlen(bf->_buf)&&j<sizeof(bf->_method)-1)
    {
        bf->_method[j]=bf->_buf[i];//get method
        ++i;
        ++j;
    }
    bf->_method[j]=‘\0‘;
    //printf("method:%s\n",bf->_method);    
    j=0;
    while(‘\0‘!=bf->_buf[i]&&isspace(bf->_buf[i]))
    {
        ++i;
    }
    while(‘\0‘!=bf->_buf[i]&&!isspace(bf->_buf[i])&&i<strlen(bf->_buf)&&j<sizeof(url)-1)
    {
        url[j]=bf->_buf[i];
        ++j;
        ++i;
    }
    url[j]=‘\0‘;
    //printf("url:%s\n",url);
    bf->_cgi=0;
    if(strcasecmp(bf->_method,"POST")!=0&&strcasecmp(bf->_method,"GET")!=0)
    {
        echo_error(bf,500);
        bf->_err=1;
        //return;
    }
    bf->_query_string=NULL;
    if(strcasecmp(bf->_method,"POST")==0)
    {
        bf->_cgi=1;
        bf->_query_string=NULL;
    }
    if(strcasecmp(bf->_method,"GET")==0)
    {
        bf->_query_string=url;
        while(*bf->_query_string!=‘\0‘&&*bf->_query_string!=‘?‘)
        {
            ++bf->_query_string;                  
        }
            
        //printf("query_string::::::::::::::::\n");     
        if(*bf->_query_string==‘?‘)
        {
           *bf->_query_string=‘\0‘;
           bf->_cgi=1;
           ++bf->_query_string;
        }
    }
    
    sprintf(bf->_path,"htdocs%s",url);
    struct stat st;
    if(stat(bf->_path,&st)<0)//not exist
    {
        echo_error(bf,404);
        bf->_err=1;
        //return;
    
    }
    else if(S_IFDIR&st.st_mode)//dir
    {
        if(strcmp(bf->_path,"htdocs/")!=0)
            strcpy(bf->_path,"htdocs/");
        strcat(bf->_path,_DEF_PAGE_);
    }                                   
   else if((st.st_mode&S_IXUSR)||(st.st_mode&S_IXGRP)||(st.st_mode&S_IXOTH))
    {
        bf->_cgi=1;
    }
//  printf("%d:%s\n",bf->_cgi,bf->_path);
    if(bf->_err==0)
    {
        if(bf->_cgi)
        {
            execute_cgi(bf);
        }
        else
        {
            clear_head(bf->_fd);
            bf->_st_size=st.st_size;
            echo_html(bf);
        }
    }
}                                      
//cgi_math.h
#include<iostream>
#include<string>
#include<string.h>
#include<stdlib.h>
#include<errno.h>
#include<vector>
#include<assert.h>
using namespace std;
#define INT_64 long long
#define UN_INIT  0xcccccccccccccccc//不能分开
#define MIN_INT (unsigned)0xffffffff
#define MAX_INT (unsigned)0x7fffffff
class BigData
{
public:
	BigData()
	:_data(0)
	,_pdata("")
	{}
	BigData(INT_64 data)
	:_data(data)
	{
		int tmp=_data;
		char symbol=‘+‘;
		if(tmp<0)
		{
			symbol=‘-‘;
			tmp=0-tmp;
		}
		_pdata.append(1,symbol);
		while(tmp)
		{
			_pdata.append(1,tmp%10+‘0‘);
			tmp/=10;
		}
		char* str=(char*)_pdata.c_str()+1;
		while(*str==‘0‘)
		{
			++str;
		}
		char* left=str;
		char* right=(char*)(_pdata.c_str()+_pdata.size()-1);
		char temp;
		while(left<right)
		{
			temp=*left;
			*left=*right;
			*right=temp;
			++left;
			--right;
		}
	}
	BigData(const char* str)
	{
		assert(str);
		//cout<<str<<endl;
		char* src=const_cast<char*>(str);
		INT_64 ret=0;
		char symbol=‘+‘;
		if(*src==‘+‘||*src==‘-‘)
			symbol=*src++;
		_pdata.append(1,symbol);
		while(‘0‘==*src)
			++src;
		while(*src>=‘0‘&&*src<=‘9‘)
		{
			if (ret <= MAX_INT)
				ret = ret * 10 + *src-‘0‘;
			_pdata.append(1,*src);
			++src;
		}
	//	cout<<_pdata<<endl;
		if(symbol==‘-‘)
			ret=0-ret;
		_data=ret;
	}
	BigData operator+(BigData db)
	{
		if(!IsINT64OverFlow()&&!db.IsINT64OverFlow())
		{
			if(_pdata[0]!=db._pdata[0])
				return BigData(_data+db._data);
			else
			{
				if(_pdata[0]==‘+‘&&MAX_INT-_data>=db._data||_pdata[0]==‘-‘&&_data>=MIN_INT-db._data)
					return BigData(_data+db._data);
			}
		}
		BigData tmp(*this);
		return BigData(Add(tmp._pdata,db._pdata).c_str());
	}
	BigData operator-(BigData db)
	{
		if(!IsINT64OverFlow()&&!db.IsINT64OverFlow())
		{
			if(_pdata[0]==db._pdata[0])
				return BigData(_data-db._data);
			else
			{
				if(_pdata[0]==‘+‘&&MAX_INT+db._data>=_data||_pdata[0]==‘-‘&&_data>=MIN_INT+db._data)
					return BigData(_data-db._data);
			}
		}
		string ret;
		BigData tmp(*this);
		//cout<<tmp;
		if(_pdata[0]==db._pdata[0])
			ret=Sub(tmp._pdata,db._pdata);
		else
		{
			ret=Add(tmp._pdata,db._pdata);
			ret[0]=_pdata[0];
		}
		return BigData(ret.c_str());
	}
	BigData operator*(BigData db)
	{
		if(!IsINT64OverFlow()&&!db.IsINT64OverFlow())
		{
			if(_pdata[0]==db._pdata[0])
			{
				if(_pdata[0]==‘+‘&&_data<=MAX_INT/db._data||_pdata[0]==‘-‘&&_data>=MAX_INT/db._data)
					return BigData(_data*db._data);
			}
			else
			{
				if(_pdata[0]==‘+‘&&MIN_INT/_data<=db._data||_pdata[0]==‘-‘&&_data>=MIN_INT/db._data)
						return BigData(_data*db._data);
			}
		}
		BigData tmp(*this);
		return BigData(Mul(tmp._pdata,db._pdata).c_str());
	}
	BigData operator/(BigData db)
	{
		if(_data==0||db._data==0)
			return BigData((INT_64)0);
		if(!IsINT64OverFlow()&&!db.IsINT64OverFlow())
		{
			return BigData(_data/db._data);
		}
		BigData tmp(*this);
		return BigData(Div(tmp._pdata,db._pdata).c_str());
	}
	friend ostream& operator<<(ostream& out,BigData& db)
	{
		if(!db.IsINT64OverFlow())
		{
				out<<db._data;
				return out;
		}
		if(db._pdata[0]==‘-‘)
			out<<&db._pdata[0];
		char* str=(char*)db._pdata.c_str()+1;
		while(*str==‘0‘)
			++str;
		out<<str;
		return out;
	}
protected:
	bool IsINT64OverFlow()
	{
		if(_data<=MAX_INT&&_data>=MIN_INT)
			return false;
		return true;
	}
	string Add(string& s1,string& s2)
	{
		int leftSize=s1.size();
		int rightSize=s2.size();
		char symbol=‘+‘;
		string ret;
		if(s1[0]==s2[0])
		{
			if(s1[0]==‘-‘)
				symbol=‘-‘;
		}
		else
		{
			if(s1[0]==‘+‘&&strcmp(s1.c_str()+1,s2.c_str()+1)<0||s1[0]==‘-‘&&strcmp(s1.c_str()+1,s2.c_str()+1)>0)
			{
				symbol=‘-‘;
			}
		}
		if(leftSize<rightSize)
		{
			swap(s1,s2);
			swap(leftSize,rightSize);
		}
		ret.resize(leftSize+1);
		memset((void*)ret.c_str(),‘0‘,ret.size()*sizeof(char));
		ret[0]=symbol;
		char cret,cstep=0;
		for(int dx=1;dx<leftSize;++dx)
		{
			cret=s1[leftSize-dx]-‘0‘+cstep;
			if(dx<rightSize)
				cret+=(s2[rightSize-dx]-‘0‘);
			cstep=cret/10;
			ret[leftSize-dx+1]=cret%10+‘0‘;
		}
		ret[1]=cstep+‘0‘;
		return ret;
	}
	string Sub(string& s1,string& s2)
	{
		int leftSize=s1.size();
		int rightSize=s2.size();
		char symbol=s1[0];
		if(leftSize<rightSize||leftSize==rightSize&&strcmp(s1.c_str()+1,s2.c_str()+1)<0)
		{
			swap(leftSize,rightSize);
			swap(s1,s2);
			if(symbol=‘+‘)
				symbol=‘-‘;
			else
				symbol=‘+‘;
		}
		//cout<<s1<<s2<<endl;
		string ret;
		ret.resize(leftSize);
		memset((void*)ret.c_str(),‘0‘,ret.size()*sizeof(char));
		ret[0]=symbol;
		char cret;
		//cout<<ret<<endl;
		//cout<<s1<<s2<<endl;
		for(int dx=1;dx<leftSize;++dx)
		{
			cret=s1[leftSize-dx]-‘0‘;
			if(dx<rightSize)
			{
				cret-=(s2[rightSize-dx]-‘0‘);
			}
			if(cret<0)
			{
				s1[leftSize-dx-1]-=1;
				cret+=10;
			}
		//	cout<<cret+‘0‘;
			ret[leftSize-dx]=cret+‘0‘;
		}
		return ret;
	}
	string Mul(string& s1,string& s2)
	{
		int leftSize=s1.size();
		int rightSize=s2.size();
		if(leftSize<rightSize)
		{
			swap(leftSize,rightSize);
			swap(s1,s2);
		}
		string ret;
		ret.resize(leftSize+rightSize-1);
		memset((void*)ret.c_str(),‘0‘,ret.size()*sizeof(char));
		char symbol=‘+‘;
		if(s1[0]!=s2[0])
			symbol=‘-‘;
		ret[0]=symbol;
		int dataLen=ret.size();
		int offSet=0;
		for(int dx=1;dx<rightSize;++dx)
		{
			char c1=s2[rightSize-dx]-‘0‘;
			char cstep=0;
			if(c1==0)
			{
				++offSet;
				continue;
			}
			for(int ldx=1;ldx<leftSize;++ldx)
			{
				char cret=c1*(s1[leftSize-ldx]-‘0‘);
				cret+=(cstep+ret[dataLen-ldx-offSet]-‘0‘);
				ret[dataLen-ldx-offSet]=cret%10+‘0‘;
				cstep=cret/10;
			}
			ret[dataLen-offSet-leftSize]=cstep+‘0‘;
			++offSet;
		}
	//	cout<<ret.c_str();
		return ret;
	}
	string Div(string& s1,string& s2)
	{
		int leftSize=s1.size();
		int rightSize=s2.size();
		char symbol=‘+‘;
		if(s1[0]!=s2[0])
			symbol=‘-‘;
		if(leftSize<rightSize||leftSize==rightSize&&strcmp(s1.c_str()+1,s2.c_str()+1)<0)
		{
			return "0";
		}
		else if(s2=="1"||s2=="-1")
		{
			s1[0]=symbol;
			return s1;
		}
		char* left=(char*)s1.c_str()+1;
		char* right=(char*)s2.c_str()+1;
		int dataLen=rightSize-1;
		string ret;
		ret[0]=symbol;
	//	cout<<left<<right<<endl;
		for(int dx=0;dx<leftSize-rightSize+1;++dx)
		{
			if(!leftStrRight(left,dataLen,right,rightSize-1))
			{
				++dataLen;
				ret.append(1,‘0‘);
				continue;
			}
			else
			{
				ret.append(1,subLoop(left,dataLen,right,rightSize-1));
				dataLen+=1;
			}
		}
		//cout<<ret.c_str()<<"RRRR";
		return ret;
	}
	char subLoop(char*& left,int& leftSize,char* right,int rightSize)
	{
		assert(left&&right);
		char cret=‘0‘;
		while(1)
		{
			if (!leftStrRight(left, leftSize, right, rightSize))
				break;
			int lLen=leftSize-1;
			int rLen=rightSize-1;
			while(lLen>=0&&rLen>=0)
			{
				if(left[lLen]<right[rLen])
				{
					if(lLen<1)
						break;
					left[lLen-1]-=1;
					left[lLen]+=10;
				}
				left[lLen]-=right[rLen];
				left[lLen]+=‘0‘;
				--lLen;
				--rLen;
			}
			while(*left==‘0‘)
			{
				++left;
				--leftSize;
			}
			cret++;
		}
		return cret;
	}
	bool leftStrRight(char* left,int leftLen,char* right,int rightLen)
	{
		assert(left&&right);
		if(leftLen>rightLen||leftLen==rightLen&&strcmp(left,right)>0)
			return true;
		return false;
	}
private:
	INT_64 _data;
	string _pdata;
};
void analy_query(char * query_string,vector<string>& v);
void obtain_query_string(string& query_string);
//cgi_math.cpp
#include"cgi_math.h"
void analy_query(char * query_string,vector<string>& v)
{
	int i=strlen(query_string);
	for(;i>0;--i)//obtain
	{
		if(query_string[i-1]==‘=‘)
		{
			v.push_back(&query_string[i]);//i-1+1
		}
		else if(query_string[i-1]==‘&‘)
		{
			query_string[i-1]=‘\0‘;
		}
	}
}
void obtain_query_string(string& query_string)
{
	char method[1024];
	char buf[1024];
	memset(buf,‘\0‘,sizeof(buf));
	int content_length=0;
	if(getenv("REQUEST_METHOD"))
	{
		strcpy(method,getenv("REQUEST_METHOD"));
	}
	else
	{
		cout<<strerror(errno)<<endl;
		return;
	}
	if(strcasecmp(method,"GET")==0)
	{
		query_string+=getenv("QUERY_STRING");
	}
	else//POST
	{
		ssize_t _s=-1;
		if((_s=read(0,buf,sizeof(buf)))>0)
		{
			buf[_s]=‘\0‘;
			query_string+=buf;
		}
	}
	//cout<<query_string;
	//num1=100&num2=200
}
//add.cpp
#include"cgi_math.h"
int main()
{
	string query_string;
	obtain_query_string(query_string);
	vector<string> v;

	analy_query((char*)(query_string.c_str()),v);
	BigData b1(v[1].c_str());
	BigData b2(v[0].c_str());
	BigData ret=b1+b2;
	cout<<b1<<"+"<<b2<<"="<<ret<<endl;
}
//sub.cpp
#include"cgi_math.h"
int main()
{
	string query_string;
	obtain_query_string(query_string);
	vector<string> v;
	analy_query((char*)query_string.c_str(),v);
	BigData b1(v[1].c_str());
	BigData b2(v[0].c_str());
	BigData ret=b1-b2;
	cout<<b1<<"-"<<b2<<"="<<ret<<endl;
}
//mul.cpp
#include"cgi_math.h"
int main()
{
	string query_string;
	obtain_query_string(query_string);
	vector<string> v;
	analy_query((char*)query_string.c_str(),v);
	BigData b1(v[1].c_str());
	BigData b2(v[0].c_str());
	//BigData b1("1234");
	//BigData b2("2344");
	BigData ret=b1*b2;
	cout<<b1<<"*"<<b2<<"="<<ret<<endl;
}
//div.cpp
#include"cgi_math.h"
int main()
{
	string query_string;
	obtain_query_string(query_string);
	vector<string> v;
	analy_query((char*)query_string.c_str(),v);
	BigData b1(v[1].c_str());
	BigData b2(v[0].c_str());
	//BigData b1("1234");
	//BigData b2("12");
	BigData ret=b1/b2;
	cout<<b1<<"/"<<b2<<"="<<ret<<endl;
}
//remain.cpp
#include"cgi_math.h"
int main()
{
	string query_string;
	obtain_query_string(query_string);
	vector<string> v;
	analy_query((char*)query_string.c_str(),v);
	BigData num1(v[1].c_str());
	BigData num2(v[0].c_str());
	//BigData num1(1234);
	//BigData num2(12);
	BigData num4=num1/num2;
	//cout<<num4<<endl;
	BigData num5=num4*num2;
	//cout<<num5<<endl;
	BigData num6=num1-num5;
	//cout<<num3<<num5;

	cout<<num1<<"%"<<num2<<"="<<num6<<endl;
}
//Makefile
.PHONY:all 
all:cgi_add cgi_sub cgi_mul cgi_div cgi_remain

cgi_add:cgi_add.cpp cgi_math.cpp
	g++ -o [email protected] $^
cgi_sub:cgi_sub.cpp cgi_math.cpp
	g++ -o [email protected] $^
cgi_mul:cgi_mul.cpp cgi_math.cpp
	g++ -o [email protected] $^
cgi_div:cgi_div.cpp cgi_math.cpp
	g++ -o [email protected] $^
cgi_remain:cgi_remain.cpp cgi_math.cpp
	g++ -o [email protected] $^
.PHONY:clean
clean:
	rm -f cgi_add cgi_sub cgi_mul cgi_div cgi_remain
//总的Makefile
ROOT_PATH=$(shell pwd)
LDFLAGS=-lpthread
FLAGS=#_DEBUG1_
CC=gcc
BIN=httpd

CGI_BIN=htdocs/cgi_bin
SRC=$(shell ls *.c)
OBJ=$(SRC:.c=.o)

$(BIN):$(OBJ)
	@echo "Linking [$^] to [[email protected]]"
	@$(CC) -o [email protected] $^ $(LDFLAGS)
	@echo "Linking done..."
%.o:%.c
	@echo "Compling [$<] to [[email protected]]"
	@$(CC) -c $<
	@echo "Compling done..."
.PHONY:clean
clean:
	@rm -rf *.o $(BIN) output
	@for name in `echo $(CGI_BIN)`;	do		cd $$name;		make clean;		cd -;	done

.PHONY:cgi
cgi:
	@for name in `echo $(CGI_BIN)`;	do		cd $$name;		make;		cd -;	done

.PHONY:output
output:$(BIN) cgi
	@mkdir -p output/log
	@cp -rf htdocs output
	@mkdir -p output/htdocs/cgi_bin
	@cp -f httpd output/
	@cp -f start.sh output/
	@cp -rf conf output
	@for name in `echo $(CGI_BIN)`;	do		cd $$name;		make output;		cd -;	done
//main.c
#include"http.h"
int main(int argc,char* argv[])
{
	if(argc!=3)
	{
		usage(argv[0]);
		return 1;
	}
	char* ip=argv[1];
	int port=atoi(argv[2]);
	int listen_sock=startup(ip,port);
	struct sockaddr_in client;
	socklen_t len=sizeof(client);
	int epo_fd=epoll_create(256);
	if(epo_fd<0)//success:not 0 fd/error:-1
	{
		printLog(strerror(errno),__FUNCTION__,__LINE__);
		return -1;
	}
	bf_p fd_bf=(bf_p)malloc(sizeof(bf_t));
	memset(fd_bf->_buf,‘\0‘,sizeof(fd_bf->_buf));
	fd_bf->_fd=listen_sock;
	struct epoll_event ev;
	ev.events=EPOLLIN;
	ev.data.fd=listen_sock;
	if(epoll_ctl(epo_fd,EPOLL_CTL_ADD,listen_sock,&ev)<0)//success:0 fail:-1
	{
		printLog(strerror(errno),__FUNCTION__,__LINE__);
		return -1;
	}
	struct epoll_event evfds[_SIZE_];//_SIZE_ 1024
	int _timeout=5000;
	int ret=-1;

	int i=0;
	while(1)
	{
		switch((ret=epoll_wait(epo_fd,evfds,_SIZE_,_timeout)))
		{
			case -1://error
				printLog(strerror(errno),__FUNCTION__,__LINE__);
				break;
			case 0://time out
				printf("time out...\n");
				break;
			default://normal
				{
					for(i=0;i<ret;++i)
					{
						if(evfds[i].data.fd==listen_sock&&evfds[i].events&EPOLLIN)
						{
							int new_sock=accept(listen_sock,(struct sockaddr*)&client,&len);
							if(new_sock<0)
							{
								printLog(strerror(errno),__FUNCTION__,__LINE__);
								continue;
							}
							bf_p _bf=(bf_p)malloc(sizeof( bf_t));
							memset(_bf->_buf,‘\0‘,sizeof(_bf->_buf));
							_bf->_fd=new_sock;

							ev.events=EPOLLIN;
							ev.data.ptr=_bf;
							epoll_ctl(epo_fd,EPOLL_CTL_ADD,new_sock,&ev);
						}
						else if(((bf_p)(evfds[i].data.ptr))->_fd>0&&evfds[i].events&EPOLLIN)
						{
							accept_request(evfds[i].data.ptr);
							ev.events=EPOLLOUT;
							ev.data.ptr=evfds[i].data.ptr;
							epoll_ctl(epo_fd,EPOLL_CTL_MOD,((bf_p)(evfds[i].data.ptr))->_fd,&ev);
						}
						else if(((bf_p)(evfds[i].data.ptr))->_fd>0&&evfds[i].events&EPOLLOUT)
						{
							bf_p _bf=(bf_p)evfds[i].data.ptr;
							if(_bf->_err)
							{
								send(_bf->_fd,_bf->_buf,strlen(_bf->_buf),0);
							}
							else if(_bf->_cgi)//cgi=1
							{
								send(_bf->_fd,_bf->_buf,strlen(_bf->_buf),0);
							}
							else
							{
								char* path=_bf->_path;
								int fd=open(path,O_RDONLY);
								if(fd<0)
								{
									printLog(strerror(errno),__FUNCTION__,__LINE__);
									exit(1);
								}
								send(_bf->_fd,_bf->_buf,strlen(_bf->_buf),0);
								if(sendfile(_bf->_fd,fd,NULL,_bf->_st_size)<0)
								{
									printf("error");
								}
								close(fd);
							}

							epoll_ctl(epo_fd,EPOLL_CTL_DEL,_bf->_fd,NULL);
							close(_bf->_fd);
							free(_bf);
						}
					}

					break;
				}
		}
	}
	return 0;
}
时间: 2025-01-02 17:21:38

大数运算+web服务器的相关文章

php与web服务器关系

在解析这个问题前,先要讲述一个概念,什么是cgi程序? 1.什么是cgi程序,cgi与fastcgi的区别 CGI的中文名称是通用网关接口,是外部应用程序与web服务器之间的接口标准.CGI规范允许web服务器执行外部程序,并将它们的输出发送给web浏览器.而fastcgi则是一个常驻型的cgi,它可以一直执行着,不需求每次请求都必须fork进程来处理,此外,它还支持分布式运算,接受来自其他服务器的请求. 以下表格总结出它们的异同点:   web服务器 处理进程 CGI fork一个新的进程处理

嵌入式web服务器

现在在嵌入式设备中所使用的web服务器主要有:boa.thttpd.mini_httpd.shttpd.lighttpd.goaheand.appweb和apache等. Boa 1.介绍 Boa诞生于1991年,作者Paul Philips.是开源的,应用很广泛,特别适合于嵌入式设备,网上流行程度很广.它的官方网站说boa是最受人喜爱的嵌入式web服务器.功能较为强大,支持认证,cgi等.Boa 是一个单任务的HTTP SERVER,它不像传统的web服务器那样为每个访问连接开启一个进程,也不

Web服务器父与子 Apache和Tomcat区别

http://developer.51cto.com/art/201007/210894.htm 熟悉三国的朋友都知道曹操,曹操有二十五个儿子,其中最得曹操宠爱的是曹丕.曹植.曹彰三个,曹丕性格阴冷,擅长政治:曹植才华横溢,放浪不羁:曹彰武艺高强,战功卓著.曹操一直希望这三个儿子当中选取自己的继承人,最后与曹操性格最为相近的曹丕脱颖而出.但是我们永远都不会否认曹植的才华和曹彰的武功. Apache是世界使用排名第一的Web服务器软件.它可以运行在几乎所有广泛使用的计算机平台上,由于其跨平台和安全

Web服务器Tomcat集群与负载均衡技术

我们曾经介绍过三种Tomcat集群方式的优缺点分析.本文将介绍Tomcat集群与负载均衡技术具体实施过程. 在进入集群系统架构探讨之前,先定义一些专门术语: 1. 集群(Cluster):是一组独立的计算机系统构成一个松耦合的多处理器系统,它们之间通过网络实现进程间的通信.应用程序可以通过网络共享内存进行消息传送,实现分布式计算机. 2. 负载均衡(Load Balance):先得从集群讲起,集群就是一组连在一起的计算机,从外部看它是一个系统,各节点可以是不同的操作系统或不同硬件构成的计算机.如

Tengine,轻量级Web服务器

阿里妹导读:Tengine,轻量级Web服务器,基于Nginx进行开发,针对大访问量网站的需求,新增了很多高级功能和特性.比如,Tengine兼容Nginx的所有配置,并且增加了独立进程框架.页面优化.集成了Lua语言进行扩展等很多实用的功能,并在性能方面做了较大的提升.阿里全站HTTPS项目诞生的七层流量入口网关"接入层"也是基于Tengine,目前90%以上的流量都是HTTPS,它是如何支撑双11零点流量高峰如丝般顺滑? 背景介绍 虽然全站HTTPS已经是一个老生常谈的话题,但是国

Node.js作web服务器总结

1.为什么Node.js用JS开发 首先,我们都清楚的是,同时接收数量众多的请求是服务器非常常见的情况.而web应用程序架构(包括流量.处理器速度和内存速度)中的瓶颈在于:服务器能够处理的并发连接的最大数量.解决这个瓶颈,有三种方法: ①系统线程模型:服务端只有一个线程,并发请求(用户)到达只能处理一个,其余的要先等待,这就是阻塞,正在享受服务的请求阻塞后面的请求了. ②多线程.线程池模型:调节服务端线程的数量来提高对并发请求的接收和响应,但并发量高的时候,请求仍然需要等待.它有个更严重的问题,

web服务器原理

一.概述 Web服务器概念较为广泛,我们最常说的Web服务器指的是网站服务器,它是建立在Internet之上并且驻留在某种计算机上的程序.Web服务器可以向Web客户端(如浏览器)提供文档或其他服务,只要是遵循HTTP协议而设计的网络应用程序都可以是Web客户端. 二.web服务器工作原理 假设把浏览器当作客户端 1.用户做出了一个操作,可以是填写网址敲回车,可以是点击链接,可以是点击按键等,接着浏览器获取了该事件. 2.浏览器与对端服务程序建立TCP连接. 3.浏览器将用户的事件按照HTTP协

pfsense Web服务器负载平衡配置示例

在pfsense的网关和服务器中有两种类型的负载平衡功能.网关负载平衡可以通过多个WAN连接分发Internet绑定的流量.服务器负载平衡管理传入流量,因此它利用多个内部服务器进行负载分配和冗余,服务器负载平衡允许流量在多个内部服务器之间分配,它最常用于Web服务器和SMTP服务器.下面我们就以实例来介绍服务器负载平衡的设置. 下面介绍如何通过pfsense2.32配置Web服务器的负载平衡. 网络环境 服务器负载平衡示例网络环境 上图为示例网络环境.它由单个防火墙组成,使用其WAN IP地址池

VS2013 VS2015 VS2017调试出现无法启动iis express web服务器

最近老是遇到这个问题,天天如此,烦死人,网上答案繁多,但是都解决不了,也是由于各种环境不同导致的,这里把几种解决方法都记录下 一.其他项目都可以,就这么一个不行 因为其他项目都可以,就这么一个不行,所以基本就是配置问题,网上的办法都试了,我试了都没用,现在说说我的解决办法 用记事本或者其他什么文本编辑器,打开项目的.csproj文件,定位到<WebProjectProperties>,把关于IIS的配置<DevelopmentServerPort>.<DevelopmentS