在上篇文章中我们已经得到了goahead的源码及测试程序,这篇文章将讲解如何使用asp。
进入goahead-test所在的目录,使用—help选项先熟悉一下其使用方法,见图1:
图1
选项 | 功能 |
--auth | 指定用户认证的配置文件 |
--background | 作为守护进程运行 |
--debugger | 运行在调试模式 |
--home | 指定运行的根目录 |
--log | 输出一些日志信息 |
--route | 指定route.txt配置文件 |
--verbose | 和—log选项一样 |
--version | 版本信息 |
输入以下的命令就可以运行goahead服务器了(-v选项等同于--verbose):
./goahead-test -v ../../../test/web/
运行时可能出现的错误及解决方案:
goahead: 0: Cannot open config file route.txt
goahead: 0: Cannot initialize server. Exiting
拷贝goahead-5.1.1/test/目录下的route.txt到当前目录或者使用—home选项重新指定运行目录
goahead: 0: Cannot open config file auth.txt
goahead: 0: Cannot load auth.txt
拷贝goahead-5.1.1/test/目录下的auth.txt到当前目录或者使用—auth选项重新指定目录
运行后如图2所示:
图2
注意IP和端口是可以自己指定的,goahead-test对应的主程序为goahead-5.1.1/test/test.c,宏ME_GOAHEAD_LISTEN定义了相应的IP和端口,修改后重新编译即可。
打开浏览器输入127.0.0.1:18080即可访问index.html主页,如果要以https方式访问,则必须明确指定为https方式,否则运行会报错,如https://127.0.0.1:14443,网页响应后可看到内容Hello /index.html(见图3),这个内容就是goahead-5.1.1/test/web/index.html文件里面的内容,主页可以访问了,下一步我们测试一下官方提供的asp。
图3
在web目录下可以找到一个test.asp文件,其内容只是显示一串英文Hello ASP World,输入127.0.0.1:18080/test.asp即可访问这个asp文件了,网页响应后就可以在网页上看到输出的内容。
打开test.c文件,在main函数中我们可以找到如下的两段代码,通过这种方式我们就可以定义自己的asp了:
#if ME_GOAHEAD_JAVASCRIPT
websDefineJst("aspTest", aspTest);
websDefineJst("bigTest", bigTest);
#endif
#if ME_GOAHEAD_JAVASCRIPT
/*
Parse the form variables: name, address and echo back
*/
static int aspTest(int eid, Webs *wp, int argc, char **argv)
{
char *name, *address;
if (jsArgs(argc, argv, "%s %s", &name, &address) < 2) {
websError(wp, 400, "Insufficient args\n");
return -1;
}
return (int) websWrite(wp, "Name: %s, Address %s", name, address);
}
/*
Generate a large response
*/
static int bigTest(int eid, Webs *wp, int argc, char **argv)
{
int i;
websSetStatus(wp, 200);
websWriteHeaders(wp, -1, 0);
websWriteEndHeaders(wp);
websWrite(wp, "<html>\n");
for (i = 0; i < 800; i++) {
websWrite(wp, " Line: %05d %s", i, "aaaaaaaaaaaaaaaaaabbbbbbbbbbbbbbbbccccccccccccccccccddddddd<br/>\r\n");
}
websWrite(wp, "</html>\n");
websDone(wp);
return 0;
}
#endif
其定义了两个js,那么要怎样才能在页面上看到这两个js呢?
将test.asp修改成如下的内容(只是将%%之间的内容替换为了我们想要显示的asp,aspTest是带有两个参数的,所以必须传参):
<html>
<body>
<% aspTest("name","address"); %>
</br>
<% bigTest(); %>
</body>
</html>
再次通过浏览器访问127.0.0.1:18080/test.asp,函数aspTest和bigTest会被执行,即可看到相应的输出内容了(见图4)。
图4
P.S. 想学习html的可以看此链接(https://www.w3school.com.cn/),了解基础的东西基本够了,我也只会一点儿,所以讲的html相关的我也不能保证绝对正确。