我正在尝试为我的脚本实现一个restful处理程序,将/
替换为&
,这样我就可以将这样的url:?script.c&things
转换为:?script/things
。目前我只有一个基于Gil this帖子的测试脚本。
// ============================================================================
// 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: %i\n", (long)argv[0] );
if(state != HDL_AFTER_READ)
return 255;
xbuf_t *read_xbuf = (xbuf_t*)get_env(argv, READ_XBUF);
printf("req_1: %.20s\n", read_xbuf->ptr);
xbuf_replfrto(read_xbuf, read_xbuf->ptr, read_xbuf->ptr + 16, "/", "&");
printf("req_2: %.20s\n-------------------\n\n", read_xbuf->ptr);
return 255; // continue G-WAN's default execution path
}
// ============================================================================
// End of Source Code
// ============================================================================
在这个脚本中,我有一个printf("Catching Gwan State: %lu\n", (long)argv[0] );
行应该打印它获得的状态(0-8,我猜),但它会继续打印
Catching Gwan State: -38241808
我不知道-38241808是什么
任何帮助?我的操作系统是Linux Mint 14,Gwan版本4.2.19
[编辑]即使使用Gwan附带的main_generic.c处理程序示例,也会给出这些奇怪的状态值
答案 0 :(得分:2)
我正在尝试为我的脚本实现一个restful处理程序来替换/ with和amp;所以我可以将这样的网址改为:
?script.c&things
:?script/things
。
G-WAN自动 。绝对不需要处理程序。 PDF手册和时间轴中记录了RESTful
功能。
您甚至可以定义哪种编程语言是默认语言(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.c&123&456
G-WAN示例使用/?argv/123/456
代替...
答案 1 :(得分:-1)
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。