📄 main.c
字号:
/* * 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 + -