⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 main.c

📁 一个典型的用于嵌入式Linux环境的Webserver
💻 C
📖 第 1 页 / 共 2 页
字号:
/* * main.c -- Main program for the GoAhead WebServer (VxWorks version) * * Copyright (c) GoAhead Software Inc., 1995-2000. All Rights Reserved. * * See the file "license.txt" for usage and redistribution license requirements * * $Id: main.c,v 1.3 2002/01/24 21:57:47 bporter Exp $ *//******************************** Description *********************************//* *	Main program for for the GoAhead WebServer. This is a demonstration *	main program to initialize and configure the web server. *//********************************* Includes ***********************************/#include	<envLib.h>#include	<hostLib.h>#include	<iosLib.h>#include	<loadLib.h>#include	<sigLib.h>#include	<sysSymTbl.h>#include	<unldLib.h>#include	"../uemf.h"#include	"../wsIntrn.h"#ifdef WEBS_SSL_SUPPORT#include	"../websSSL.h"#endif#ifdef USER_MANAGEMENT_SUPPORT#include	"../um.h"void	formDefineUserMgmt(void);#endif/*********************************** Locals ***********************************//* *	Change configuration here */#define				ROOT_DIR		T("/ata0/webs")static char_t		*rootWeb = T("web");			/* Root web directory */static char_t		*password = T("");				/* Security password */static int			port = 80;						/* Server port */static int			retries = 5;					/* Server port retries */static int			finished;						/* Finished flag *//****************************** Forward Declarations **************************/static int 	initWebs();static int	aspTest(int eid, webs_t wp, int argc, char_t **argv);static void formTest(webs_t wp, char_t *path, char_t *query);static int  websHomePageHandler(webs_t wp, char_t *urlPrefix, char_t *webDir,				int arg, char_t *url, char_t *path, char_t *query);static void vxWebsCgiEntry(void *entryAddr(int argc, char_t **argv),				char_t **argv, char_t **envp, char_t *stdIn, char_t *stdOut);static void websTermSigHandler(int signo);extern void defaultErrorHandler(int etype, char_t *msg);extern void defaultTraceHandler(int level, char_t *buf);#ifdef B_STATSstatic void printMemStats(int handle, char_t *fmt, ...);static void memLeaks();#endif/*********************************** Code *************************************//* *	Main -- entry point from VXWORKS */int websvxmain(int argc, char **argv){/* *	Initialize the memory allocator. Allow use of malloc and start  *	with a 60K heap.  For each page request approx 8KB is allocated. *	60KB allows for several concurrent page requests.  If more space *	is required, malloc will be used for the overflow. */	bopen(NULL, (60 * 1024), B_USE_MALLOC);/* *	Initialize the web server */	finished = 0;	if (initWebs() < 0) {		return -1;	}#ifdef WEBS_SSL_SUPPORT	websSSLOpen();#endif/* *	Basic event loop. SocketReady returns true when a socket is ready for *	service. SocketSelect will block for two seconds or until an event *	occurs. SocketProcess will actually do the servicing. */	while (!finished) {		if (socketReady(-1) || socketSelect(-1, 2000)) {			socketProcess(-1);		}		websCgiCleanup();		emfSchedProcess();	}#ifdef WEBS_SSL_SUPPORT	websSSLClose();#endif#ifdef USER_MANAGEMENT_SUPPORT	umClose();#endif/* *	Close the socket module, report memory leaks and close the memory allocator */	websCloseServer();	websDefaultClose();	socketClose();	symSubClose();#ifdef B_STATS	memLeaks();#endif	bclose();	return 0;}/******************************************************************************//* *	Initialize the web server. */static int initWebs(){	struct in_addr	intaddr;	char			*pString;	char			host[64], webdir[128];	char_t			wbuf[128];/* *	Initialize the socket and sym subsystems */	socketOpen();	symSubOpen();#ifdef USER_MANAGEMENT_SUPPORT/* *	Initialize the User Management database */	umOpen();	umRestore(T("umconfig.txt"));#endif/* *	Define the local Ip address, host name, default home page and the  *	root web directory. */	if (gethostname(host, sizeof(host)) < 0) {		error(E_L, E_LOG, T("Can't get hostname"));		return -1;	}	intaddr.s_addr = (unsigned long) hostGetByName(host);/* *	Set ../web as the root web. Modify this to suit your needs */	sprintf(webdir, "%s/%s", ROOT_DIR, rootWeb);/* *	Configure the web server options before opening the web server */	websSetDefaultDir(webdir);	pString = inet_ntoa(intaddr);	ascToUni(wbuf, pString, min(strlen(pString) + 1, sizeof(wbuf)));	free(pString);	websSetIpaddr(wbuf);	ascToUni(wbuf, host, min(strlen(host) + 1, sizeof(wbuf)));	websSetHost(wbuf);/* *	Configure the web server options before opening the web server */	websSetDefaultPage(T("default.asp"));	websSetPassword(password);/*  *	Open the web server on the given port. If that port is taken, try *	the next sequential port for up to "retries" attempts. */	websOpenServer(port, retries);/* * 	First create the URL handlers. Note: handlers are called in sorted order *	with the longest path handler examined first. Here we define the security  *	handler, forms handler and the default web page handler. */	websUrlHandlerDefine(T(""), NULL, 0, websSecurityHandler, 		WEBS_HANDLER_FIRST);	websUrlHandlerDefine(T("/goform"), NULL, 0, websFormHandler, 0);	websUrlHandlerDefine(T("/cgi-bin"), NULL, 0, websCgiHandler, 0);	websUrlHandlerDefine(T(""), NULL, 0, websDefaultHandler, 		WEBS_HANDLER_LAST); /* *	Now define two test procedures. Replace these with your application *	relevant ASP script procedures and form functions. */	websAspDefine(T("aspTest"), aspTest);	websFormDefine(T("formTest"), formTest);/* *	Create the Form handlers for the User Management pages */#ifdef USER_MANAGEMENT_SUPPORT	formDefineUserMgmt();#endif/* *	Create a handler for the default home page */	websUrlHandlerDefine(T("/"), NULL, 0, websHomePageHandler, 0); /* *	Provide signal for clean up on termination. */	signal(SIGTERM,	websTermSigHandler);	signal(SIGKILL,	websTermSigHandler);	return 0;}/******************************************************************************//* *	Test Javascript binding for ASP. This will be invoked when "aspTest" is *	embedded in an ASP page. See web/asp.asp for usage. Set browser to  *	"localhost/asp.asp" to test. */static int aspTest(int eid, webs_t wp, int argc, char_t **argv){	char_t	*name, *address;	if (ejArgs(argc, argv, T("%s %s"), &name, &address) < 2) {		websError(wp, 400, T("Insufficient args\n"));		return -1;	}	return websWrite(wp, T("Name: %s, Address %s"), name, address);}/******************************************************************************//* *	Test form for posted data (in-memory CGI). This will be called when the *	form in web/forms.asp is invoked. Set browser to "localhost/forms.asp" to test. */static void formTest(webs_t wp, char_t *path, char_t *query){	char_t	*name, *address;	name = websGetVar(wp, T("name"), T("Joe Smith")); 	address = websGetVar(wp, T("address"), T("1212 Milky Way Ave.")); 	websHeader(wp);	websWrite(wp, T("<body><h2>Name: %s, Address: %s</h2>\n"), name, address);	websFooter(wp);	websDone(wp, 200);}/******************************************************************************//* *	Home page handler */static int websHomePageHandler(webs_t wp, char_t *urlPrefix, char_t *webDir,	int arg, char_t *url, char_t *path, char_t *query){/* *	If the empty or "/" URL is invoked, redirect default URLs to the home page */	if (*url == '\0' || gstrcmp(url, T("/")) == 0) {		websRedirect(wp, T("home.asp"));		return 1;	}	return 0;}/******************************************************************************//* *	Returns a pointer to an allocated qualified unique temporary file name. *	This filename must eventually be deleted with bfree(); */char_t *websGetCgiCommName(){	char_t	*tname, buf[FNAMESIZE];	fmtAlloc(&tname,FNAMESIZE, T("%s/%s"), ggetcwd(buf, FNAMESIZE),			tmpnam(NULL));	return tname;}/******************************************************************************//* *	Launch the CGI process and return a handle to it. Process spawning *	is not supported in VxWorks.  Instead, we spawn a "task".  A major *	difference is that we have to know the entry point for the taskSpawn *	API.  Also the module may have to be loaded before being executed; *	it may also be part of the OS image, in which case it cannot be  *	loaded or unloaded.  The following sequence is used: *	1. If the module is already loaded, unload it from memory. *	2. Search for a query string keyword=value pair in the environment  *		variables where the keyword	is cgientry.  If found use its value *		as the the entry point name.  If there is no such pair set  *		the entry point name to the default: basename_cgientry, where *		basename is the name of the cgi file without the extension.  Use *		the	entry point name in a symbol table search for that name to *		use as the entry point address.  If successful go to step 5. *	3. Try to load the module into memory.  If not successful error out. *	4. If step 3 is successful repeat the entry point search from step *		2.  If the entry point exists, go to step 5.  If it does not, *		error out. *	5. Use taskSpawn to start a new task which uses vxWebsCgiEntry  *		as its starting point.  The five arguments to vxWebsCgiEntry

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -