我正在尝试为我的脚本实现一个restful处理程序,用&
替换/
,这样我就可以将url的如下所示:?script.c&things
变成如下所示的:?script/things
。目前,我只有一个测试脚本,是基于这篇文章的吉尔。
// ============================================================================
// Handler C script for the G-WAN Web Application Server (http://gwan.ch/)
// ----------------------------------------------------------------------------
// main.c: basic rewrite example
// ============================================================================
#include "gwan.h" // G-WAN exported functions
#include <stdio.h> // puts(), printf()
// ----------------------------------------------------------------------------
// init() will initialize your data structures, load your files, etc.
// ----------------------------------------------------------------------------
// init() should return -1 if failure (to allocate memory for example)
int init(int argc, char *argv[])
{
// define which handler states we want to be notified in main():
// enum HANDLER_ACT {
// HDL_INIT = 0,
// HDL_AFTER_ACCEPT, // just after accept (only client IP address setup)
// HDL_AFTER_READ, // each time a read was done until HTTP request OK
// HDL_BEFORE_PARSE, // HTTP verb/URI validated but HTTP headers are not
// HDL_AFTER_PARSE, // HTTP headers validated, ready to build reply
// HDL_BEFORE_WRITE, // after a reply was built, but before it is sent
// HDL_HTTP_ERRORS, // when G-WAN is going to reply with an HTTP error
// HDL_CLEANUP };
u32 *states = (u32*)get_env(argv, US_HANDLER_STATES);
*states = (1 << HDL_AFTER_READ);
return 0;
}
// ----------------------------------------------------------------------------
// clean() will free any allocated memory and possibly log summarized stats
// ----------------------------------------------------------------------------
void clean(int argc, char *argv[])
{}
// ----------------------------------------------------------------------------
// main() does the job for all the connection states below:
// (see 'HTTP_Env' in gwan.h for all the values you can fetch with get_env())
// ----------------------------------------------------------------------------
int main(int argc, char *argv[])
{
// HDL_HTTP_ERRORS return values:
// 0: Close the client connection
// 2: Send a server reply based on a custom reply buffer
// 255: Continue (send a reply based on the request HTTP code)
const long state = (long)argv[0];
printf("Catching Gwan State: %in", (long)argv[0] );
if(state != HDL_AFTER_READ)
return 255;
xbuf_t *read_xbuf = (xbuf_t*)get_env(argv, READ_XBUF);
printf("req_1: %.20sn", read_xbuf->ptr);
xbuf_replfrto(read_xbuf, read_xbuf->ptr, read_xbuf->ptr + 16, "/", "&");
printf("req_2: %.20sn-------------------nn", read_xbuf->ptr);
return 255; // continue G-WAN's default execution path
}
// ============================================================================
// End of Source Code
// ============================================================================
在这个脚本中,我有一个printf("Catching Gwan State: %lun", (long)argv[0] );
行,它应该打印它得到的状态(我想是0-8(,但它一直在打印
Catching Gwan State: -38241808
我不知道38241808是
有什么帮助吗?我的操作系统是Linux Mint 14,Gwan版本4.2.19
[EDIT]即使在使用Gwan附带的main_generic.c处理程序示例时,也会给出这些奇怪的状态值
我正在尝试为我的脚本实现一个restful处理程序,它将/替换为&所以我可以把url的这个:
?script.c&things
变成这个:?script/things
。
G-WAN自动执行。绝对不需要把手。RESTful
功能在PDF手册和时间线中均有记载。
您甚至可以定义哪种编程语言是默认语言(在URI中不需要显式文件扩展名的语言(。请参阅下面的操作方法(此处来自处理程序(:
int init(int argc, char *argv[])
{
// the QUERY_CHAR character can be chosen from the following set:
// - _ . ! ~ * ' ( )
// (see RFC 2396, section "2.3. Unreserved Characters")
//
u8 *query_char = (u8*)get_env(argv, QUERY_CHAR);
*query_char = '!'; // use "/!hello.c" instead of "/?hello.c"
// by default, DEFAULT_LANG = LG_C (ANSI C)
// LG_C, LG_CPP, LG_JAVA, etc. are defined in /gwan/include/gwan.h
// and in http://gwan.com/api#env
//
u8 *lang = (u8*)get_env(argv, DEFAULT_LANG);
*lang = LG_CPP; // use "/!hello" instead of "/!hello.cpp"
return 0;
}
只需使用/?argv/123/456
的/?argv.c&123&456
G-WAN示例进行测试。。。
我在我的电脑上测试了它。如果你喜欢这样u32 *states = (u32*)get_env(argv, US_HANDLER_STATES);
*states = (1L << HDL_AFTER_ACCEPT)
| (1L << HDL_AFTER_READ)
| (1L << HDL_BEFORE_PARSE)
| (1L << HDL_AFTER_PARSE)
| (1L << HDL_HTTP_ERRORS)
| (1L << HDL_BEFORE_WRITE);
它将产生0-8。