分享

boa资料汇总

 xinyz4104 2014-11-07
boa 移植文档(2011-08-04 20:36:12)

 
boa 版本:
www.下载的Boa源码:boa-0.94.13.tar.gz
操作系统平台:

Linux —— Fedora8

交叉编译器版本:

arm-vfp-linux-gnu-gcc

开发板平台:

YL-3250

 

<一>在x86平台上的移植

一>   编译boa程序

1、下载源码程序boa-0.94.13.tar.gz

2、解压 #tar xzf boa-0.94.13.tar.gz

3、进入boa的源代码目录

      #cd boa-0.94.13/src

      4、配置

#./configure

5、编译

#make

用2.95.3以上的版本编译时会出错:

util.c:100:1: 错误:毗连“t”和“->”不能给出一个有效的预处理标识符

make: *** [util.o] 错误 1(中文版本)

util.c:100:1: error: pasting "t" and "->" does not give a valid preprocessing token

make:*** [util.o] Error 1(English version)

解决方法:

修改本目录下compat.h中的

#define TIMEZONE_OFFSET(foo) foo##->tm_gmtoff

为:

#define TIMEZONE_OFFSET(foo) foo->tm_gmtoff

再次编译,通过,会在当前目录(boa-0.94.13/src)下生成可执行文件boa。

二>   配置boa

1、在/etc下建立boa目录,并复制/boa-0.94.13/boa.conf到/etc/boa目录下,因为在/src/defines.h源码中,宏SERVER_ROOT定义了服务器的根目录,如下:

      

#ifndef SERVER_ROOT

#define SERVER_ROOT "/etc/boa"

#endif

当然也可以在运行命令时使用-c来指定根目录。

      2、修改/etc/boa.conf

      修改访问权限:      修改User nobody

为  User 0

                                         修改Group nogroup

为  Group 0

      修改cgi程序目录:修改ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/     

为  ScriptAlias /cgi-bin/ /var/www/cgi-bin/

3、设定日志目录:boa日志有两部分,ErrorLog和AccessLog,可根据自己情况设置日志目录,也可以选择默认值:

      ErrorLog /var/log/boa/error_log

      AccessLog /var/log/boa/access_log

 

下面是从网上找到的配置说明,其实就是boa.conf的中文翻译而已。

Port:boa服务器监听的端口,默认的端口是80。如果端口小于1024,则必须是 root用户启动服务器。

Listen:绑定的ip地址。不使用这个参数时,将绑定所有的地址。

User:连接到服务器的客户端的身份,可以是用户名或UID。

Group:连接到服务器的客户端的组,可以是组名或GID。

ServerAdmin:服务器出故障时要通知的邮箱地址。

ErrorLog:指定错误日志文件。如果路径没有以"/"开始,则相对于ServerRoot路径。没有配置时默认的文件是/dev/stderr。若不想记录日志,指定文件为/dev/null。

AccessLog:设置存取日志文件,与ErrorLog类似。

UseLocaltime:设置使用本地时间,使用UTC时注释这个参数。这个参数没有值。

VerboseCGILogs:在错误日志文件中记录CGI启动和停止时间,若不记录,注释这个参数。这个参数没有值。

ServerName:指定服务器的名称,当客户端使用gethostname + gethostbyname时返回给客户端。

VirtualHost:虚拟主机开关。使用此参数,则会在DocumentRoot设定的

目录添加一个ip地址作为新的DocumentRoot来

处理客户端的请求。如DocumentRoot设置为/var/www,则http://localhost/转换成/var/www/127.0.0.1/,若注释此参数,则为/var/www/。

DocumentRoot:HTML文件的根目录(也就是网站的目录)。

UserDir:指定用户目录。

DirectoryIndex:指定预生成目录信息的文件,注释此变量将使用DirectoryMaker变量。这个变量也就是设置默认主页的文件名。

DirectoryMaker:指定用于生成目录的程序,注释此变量将不允许列目录。

DirectoryCache:当DirectoryIndex文件不存在,而DirecotryMaker又被注释掉时,将列出这个参数指定目录给客户端。

KeepAliveMax:每个连接允许的请求数量。如果将此值设为" 0 ",将不限制请求的数目。

KeepAliveTimeOut:在关闭持久连接前等待下一个请求的秒数。(秒)。

MimeTypes:设置包含mimetypes信息的文件,一般是/etc/mime.types。

DefaultType:默认的mimetype类型,一般是text/html。

CGIPath:相当于给CGI程序使用的$PATH变量。

SinglePostLimit:一次POST允许最大的字节数,默认是1MB。

AddType: 增加MimeType没有指定的类型,例: AddType type extension [extension ...]。要使用cgi,必须添加cgi类型:AddType application/x-httpd-cgi cgi

Redirect:重定向文件。

Aliases:指定路径的别名。

ScriptAlias:指定脚本路径的虚拟路径。

4、根据boa.conf建立相应目录

      /var/log/boa                                  用来存放日志文件

      /var/log/boa/error_log          日志文件

      /var/log/boa/access_log      日志文件

      /var/www                         html文件目录

并在其中存放html文件(包括默认主页index.html)

      /var/www/cgi-bin                  cgi脚本目录

注意:这里/var/log/boa目录必须为可写,否则会出现错误:log.c:73 – Unable to dup2 the error log: Bad file r.)

5、关闭其它Web服务器

      在启动boa之前,还要确保Linux中其它的Web服务器已经关闭,比如httpd。

      关闭httpd:/etc/init.d/httpd stop

6、启动boa

      在src目录下执行./boa。也可以将可执行文件boa复制到/user/bin目录下或是其他PATH,然后直接在终端输入boa即可。

      运行boa后查看进程 #ps –a|grep boa应该可以看到boa正在运行

(使用普通用户无法启动boa,提示错误:[03/Aug/2011:09:04:45 +0000] log.c:73 - unable to dup2 the error log: Bad file descriptor)

 

若ps中没有看到boa进程,说明boa没有成功启动

查看/var/log/boa/error_log显示:

[03/Aug/2011:00:46:33 +0000] boa.c:226 - icky Linux kernel bug!: Success

解决方法:将boa.c中的以下内容注释掉
if (setuid(0) != -1) {
DIE("icky Linux kernel bug!");
}
---------->

重新make

7、将Windows与虚拟机的IP设在一个网段,在Windows浏览器中输入linux的IP地址,即可进入首页,即/var/www/index.html。

      编写helloworld.c,使用gcc编译为helloworld.cgi

      gcc –o helloworld.cgi helloworld.c生成helloworld.cgi

      在浏览器地址中输入:http://192.168.7.17/cgi-bin/helloworld.cgi进入helloworld.cgi

<二>移植到开发板

一>修改Makefile文件:

1、将:CC = gcc

       CPP = gcc –E

改为:

       CC = /opt/nxp/gcc-4.3.2-glibc-2.7/bin/arm-vfp-linux-gnu-gcc

       CPP = /opt/nxp/gcc-4.3.2-glibc-2.7/bin/arm-vfp-linux-gnu-gcc –E

注:根据安装的交叉编译工具进行更改

2、#make                                            编译

  #arm-vfp-linux-gnu-strip boa            去掉调试信息,减少boa体积

二>拷贝虚拟机下/etc/mime.types文件到开发板/etc目录下

开发板上根据boa配置文件建立相关文件(夹)同X86中二>配置boa

4

将可执行文件boa复制到开发板,并运行~

在Windows浏览器地址栏中输入开发板地址进行测试。

 

在板子上运行出现这个问题gethostbyname:: Resource temporarily unavailable。

解决方法:把src文件夹下的config.c里的if(!server_name){..........}(大概在266行到286行之间)注释掉,就能运行在板子上运行boa。

附录:

常见错误

这些错误内容可查看/var/log/boa/error_log文件

1>. 错误1: gethostbyname:: No such file or directory

解决办法: 修改boa.conf  去掉 ServerName www.your.org.here 前的注释符号(#)

2>. 错误1: util.c:100:1: error: pasting "t" and "->" does not give a valid preprocessing token make: *** [util.o]

解决办法: 修改 src/compat.h

找到

#define TIMEZONE_OFFSET(foo) foo##->tm_gmtoff

修改成

#define TIMEZONE_OFFSET(foo) (foo)->tm_gmtoff

3>. 错误2: boa.c:211 - getpwuid: No such file or directory

解决办法: 修改src/boa.c

注释掉下面这段程序:

if (passwdbuf == NULL) {

 DIE(”getpwuid”);

 }

if (initgroups(passwdbuf->pw_name, passwdbuf->pw_gid) == -1) {

DIE(”initgroups”);

}

即修改为:

#if 0

if (passwdbuf == NULL) {

DIE(”getpwuid”);

}

if (initgroups(passwdbuf->pw_name, passwdbuf->pw_gid) == -1) {

DIE(”initgroups”);

}

#endif

4>. 错误3: boa.c:228 - icky Linux kernel bug!: No such file or directory

解决办法: 修改src/boa.c

注释掉下面语句:

if (setuid(0) != -1) {

DIE(”icky Linux kernel bug!”);

}

即修改为:

#if 0

if (setuid(0) != -1) {

DIE(”icky Linux kernel bug!”);

}

#endif

5>. 错误4: log.c:73 unable to dup2 the error log:bad file descriptor

解决方法:

方法1> 确定日志目录对与所有用户都具有可读/写的权限

方法2> 修改src/log.c (建议采用方法1)

注释掉

if (dup2(error_log, STDERR_FILENO) == -1) {

DIE("unable to dup2 the error log");

}

即修改为:

#if 0

if (dup2(error_log, STDERR_FILENO) == -1) {

DIE("unable to dup2 the error log");

}

#endif

 

参考网址:http://www./Linux/2011-03/33485.htm

http://hi.baidu.com/??x??/blog/item/63118b3d8b9f4fe63b87ce1f.html


 


 


http://blog.sina.com.cn/s/blog_b4ed6f2f0101d0b7.html

boa测试实例

 

前面的文章里讲了如何安装、配置boa,这篇文章主要讲一下一些boa测试实例,主要涉及到html以及cgi程序的编写。

测试环境:
虚拟机(虚拟机软件为VMware)Fedora(以下与Linux为同义词),Linux的IP为192.168.184.100,通过VMnet8方式与物理机MS Windows连接,使用常用浏览器访问,如IE、Maxthon、Chrome等。

html不用介绍了。cgi全称为Common Gate Interface,它不是一种具体的语言,它可以使用其它语言来实现,比如C、C++、Perl、shell,等等。我们使用C语言来编写cgi程序。

我们需要使用到两个文件,一个是用于页面显示的使用html语言编写的hello.html,该文件放到/var/www/html目录中。另一个是用于响应该页面的cgi程序hello.c,该程序使用C语言编写,编译方式为:

$ gcc hello.c –o hello.cgi

编译后的可执行文件hello.cgi放到/var/www/cgi-bin目录中

完整的hello.html如下:







this is  is simple test of HTML



hello from Late Lee



you can visit my website at www.





  
   
      
      
      user name
      
      

      
        password
        
      
      
      
        
        
      
    

  




这个html文件分两部分,前半部分是一些常见的页面显示语句,这里包括了标题、图片显示、超链接。后半部分是我们真正的测试程序,主要设计了两个输入框,分别输入用户名和密码;两个按钮,分别是登陆和清除,这里的“登陆”并非实际中的登陆,它只是测试cgi程序的响应,结果是显示输入的信息。
注意到这一句:

它的action表明了由哪一个cgi程序来响应来自该页面的消息,而method为http响应的方法,常用的有两种,分别是“post”和“get”,这里非专业地介绍一下。post,顾名思义,就是“提交”,用于更新信息;而get,即“获取”,用于从服务器中获取、查询信息。在下文将会看到,这两者在地址栏中的区别,使用post方法时数据是不会在地址栏中显示的,而get方法则会显示。不过本文不介绍这两者的本质区别。

如果直接输入Linux的IP地址,则会显示Fedora Project的启动页面,而要访问我们的测试网页,还需要再添加一些目录才行。这里的实际地址应该是:
http://192.168.184.100/html/hello.html
当然,IP地址需要根据实际情况而改变。

下面是响应的cgi程序hello.c完整代码:

#include 
#include 
#include 

char* get_cgi_data(FILE* fp, char* method)
{
    char* input;
    int len;
    int size=1024;
    int i=0;

    if (strcmp(method, "GET") == 0)  
    {
        input getenv("QUERY_STRING");
        return input;
    }

    else if (strcmp(method, "POST") == 0)  
    {
        len atoi(getenv("CONTENT_LENGTH"));
        input (char*)malloc(sizeof(char) (size+1));

        if (len == 0)
        {
            input[0] '\0';
            return input;
        }

        while (1)
        {
            input[i] (char)fgetc(fp);
            if (i == size)
            {
                input[i+1] '\0';
                return input;
            }
            --len;

            if (feof(fp) || (!(len)))
            {
                i++;
                input[i] '\0';
                return input;
            }
            i++;
        }
    }
    return NULL;
}

int main(void)
{
    char* input;
    char* method;
    char name[64];
    char passwd[64];
    int i=0;
    int j=0;

    printf("Content-type:text/html\n\n");
    printf("The following is query result:");
    method getenv("REQUEST_METHOD");
    input get_cgi_data(stdin, method);

    printf("string is: %s", input);
    int len strlen(input);
     
    for (i=9; i
           
        if (input[i] == '&')
        {
            name[j]='\0';
            break;
        }
        
        name[j++]=input[i];
    }

     
    for (i=19+strlen(name),j=0; i<(int)strlen(input); i++)
    {
        passwd[j++] input[i];
    }
    passwd[j]='\0';

    printf("your username is %s your password is %s\n", name, passwd);

    return 0;
}

这里不讨论代码的逻辑、风格等问题。
这个程序功能十分简单,就是打印获取到的请求字符串以及用户名称和密码。该程序与普通的C语言程序并无区别,只是多了我们不常用的getenv函数,它在stdlib.h头文件中声明,作用是获取指定的环境变量的值,比如我的系统中HOME这个环境变量值为/home/latelee/,则该函数返回指向这个值的指针。这里出现了QUERY_STRING,这是boa特有的环境变量,从字面上理解为“请求字符串”,我们打印了这个变量的值,也从该字符串中分析得到用户名和密码,下面将会看到。
在boa源代码目录下的examples目录中有一个cgi程序:cgi-test.cgi,它使用perl语言编写。将它复制到/var/www/cgi-bin目录中,在浏览器输入其地址:
http://192.168.184.100/cgi-bin/cgi-test.cgi
则显示下面的cgi测试程序:

Boa CGI test
Date: Thu Jan 27 13:45:19 CST 2011 
Method: GET 
Basic GET Form:

Basic POST Form:
   
Sample ISINDEX form:
/cgi-bin/cgi-test.cgi?param1+param2+param3 Query String: 
Arguments: 
Environment: 
· SCRIPT_NAME = /cgi-bin/cgi-test.cgi 
· SERVER_NAME = FightNow 
· HTTP_ACCEPT_ENCODING = gzip, deflate 
· SERVER_ADMIN = 
· REQUEST_METHOD = GET 
· SERVER_SOFTWARE = Boa/0.94.13 
· REMOTE_PORT = 3892 
· HTTP_USER_AGENT = Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR

2.0.50727) 
· SERVER_PORT = 80 
· HTTP_ACCEPT_LANGUAGE = zh-cn 
· REMOTE_ADDR = 192.168.184.1 
· SERVER_PROTOCOL = HTTP/1.1 
· PATH = /bin:/usr/bin:/usr/local/bin 
· GATEWAY_INTERFACE = CGI/1.1 
· REQUEST_URI = /cgi-bin/cgi-test.cgi 
· SERVER_ADDR = 192.168.184.100 
· HTTP_HOST = 192.168.184.100 
No input stream: (not POST) 
id: uid=99(nobody) gid=0(root) groups=99(nobody) 
Boa http server

这里我们看到许多的环境变量以及它们的值,它们可以直接使用getenv函数获取。QUERY_STRING是客户端提交的数据,这些数据在传输过程中是经过了编码的,因此,要正确显示它们,必须进行解码。

  • 表单中每个字段用字段名后跟等号,再接上这个字段的值来表示,每个字段之间的内容用“&”连结,前面的程序就是依据“&”进行判断用户名和密码的。
  • 空格符号用加号(“+”)代替,而其它的特殊字符,如“!”、“#”等,使用百分号(“%”)加对应的ASCII码来表示。汉字也是这样表示。

下面是页面显示的效果图:

当输入用户名和密码分别输入latelee和提交后,将出现如下提示信息:

The following is query result:

string is: Username=latelee&Password=
your username is latelee
your password is 

 可见,程序正确解析出了用户名和密码,不过当字段值有空格时,则显示:

The following is query result:

string is: Username=Late+Lee&Password=Late+Lee
your username is Late+Lee
your password is Late+Lee

可以看到,还没正确解析出空格(我不知道在字段值中出现空格本身就是是非法的还是程序的问题)。

当cgi程序采用get方法时,地址栏的变化为:

http://192.168.184.100/cgi-bin/hello.cgi?Username=latelee&Password=

而采用post方法时,地址栏为:

http://192.168.184.100/cgi-bin/hello.cgi

未尽事宜:中文解析还没有完成,当用户名为“李迟”时,显示如下:

The following is query result:

string is: Username=???&Password=123
your username is ???
your password is 123


 


 

http://canlynet.blog.163.com/blog/static/25501365200911252756635/

boa webserver 的安装配置和使用  

☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆
boa webserver 是一个小巧高效的web服务器,是一个运行于unix或linux下的,支持cgi的、非常适合于嵌入式系统的单任务的http服务器,源代码开放、性能高。
☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆

Linux版本:Ubuntu 7.04
arm gcc版本:3.4.5
boa版本:
boa-0.94.13.tar.tar
下载地址:
http://www./boa-0.94.13.tar.gz

 

****************************************************
摘自:
http://blog./u1/33226/showart_485155.html
****************************************************

随着Internet技术的兴起,在嵌入式设备的管理与交互中,基于Web方式的应用成为目前的主流,这种程序结构也就是大家非常熟悉的B/S结构,即在 嵌入式设备上运行一个支持脚本或CGI功能的Web服务器,能够生成动态页面,在用户端只需要通过Web浏览器就可以对嵌入式设备进行管理和监控,非常方 便实用。
--------------------------------------------------------------------------------------------------
本节主要介绍这种应用的开发和移植工作。
用户首先需要在嵌入式设备上成功移植支持脚本或CGI功能的Web服务器,然后才能进行应用程序的开发。
1、 嵌入式Web服务器移植  由于嵌入式设备资源一般都比较有限,并且也不需要能同时处理很多用户的请求,因此不会使用Linux下最常用的如Apache 等服务器,而需要使用一些专门为嵌入式设备设计的Web服务器,这些Web服务器在存贮空间和运行时所占有的内存空间上都会非常适合于嵌入式应用场合。
典型的嵌入式Web服务器有Boa (
www.)和thttpd (http://www./software/thttpd/)等,它们和Apache等高性能的Web服务器主要的区别在于它们一般是 单进程服务器,只有在完成一个用户请求后才能响应另一个用户的请求,而无法并发响应,但这在嵌入式设备的应用场合里已经足够了。
-------------------------------------------------------------------------------------------------
我们绍比较常用的Boa服务器的移植。

Boa是一个非常小巧的Web服务器,可执行代码只有约60KB。它是一个单任务Web服务器,只能依次完成用户的请求,而不会fork出新的进程来处理 并发连接请求。但Boa支持CGI,能够为CGI程序fork出一个进程来执行。Boa的设计目标是速度和安全,在其站点公布的性能测试中,Boa的性能 要好于Apache服务器。

【第一步】完成Boa程序的移植。从www.下载Boa源码,当前最新版本为0.94.13,将其解压并进入源码目录的src子目录。

    # tar xzf boa-0.94.13.tar.gz
    # cd boa-0.94.13/src
生成Makefile文件
    # ./configure
    修改Makefile文件,找到CC=gcc,将其改成CC = arm-linux-gcc( arm-linux-gcc是3.3.2版的arm gcc编译器,如果是3.4.5版本的gcc用:arm-softfloat-linux-gnu-gcc,当使用该版本,本文其余地方都如此更改),再找到CPP = gcc –E,将其改成CPP = arm-linux-gcc –E,并保存退出。
    然后运行make进行编译,得到的可执行程序为boa,将调试信息剥去,得到的最后程序只有约60KB大小。
    # make
    # arm-linux-strip boa
--------------------------------------strip的作用-----------------------------------
linux@farsight:~/project/boa-0.94.13/src$ ls boa -l -h
-rwxr-xr-x 1 linux linux 184K 2009-12-11 10:50 boa
linux@farsight:~/project/boa-0.94.13/src$ arm-softfloat-linux-gnu-strip boa
linux@farsight:~/project/boa-0.94.13/src$ ls -l boa -h
-rwxr-xr-x 1 linux linux 60K 2009-12-11 10:58 boa
---------------------------------------------------------------------------------------

 

出错处理:
错误3:
        错误信息:
  debian:/home/a/sss/boa-0.94.13/src# make
  gcc -g -O2 -pipe -Wall -I. -c -o util.o util.c
  util.c:100:1: error: pasting "t" and "->" does not give a valid preprocessing token
  make: *** [util.o] Error 1

  解决方法:
       查找预编译出错的那个宏:
        grep TIMEZONE_OFFSET ./ -r
        ./compat.h:#define TIMEZONE_OFFSET(foo) ##foo->tm_gmtoff
        ./compat.h:#define TIMEZONE_OFFSET(foo) timezone
        ./util.c:        time_offset = TIMEZONE_OFFSET(t);
        我们可以看到查出的第一行##显然是错误输入!
  修改 src/compat.h
  找到
  #define TIMEZONE_OFFSET(foo) foo##->tm_gmtoff
  修改成
  #define TIMEZONE_OFFSET(foo) (foo)->tm_gmtoff


【第二步】完成Boa的配置,使其能够支持CGI程序的执行。Boa需要在/etc目录下建立一个boa目录,里面放入Boa的主要配置文件boa.conf。在Boa源码目录下已有一个示例boa.conf,可以在其基础上进行修改,下面解释一下该文件的含义:

#监听的端口号,缺省都是80,一般无需修改
Port 80
# bind调用的IP地址,一般注释掉,表明绑定到INADDR_ANY,通配于服务器的所有IP地址
#Listen 192.68.0.5
#作为哪个用户运行,即它拥有该用户的权限,一般都是nobody(linux默认有),需要/etc/passwd中有
#nobody用户
User nobody
#作为哪个用户组运行,即它拥有该用户组的权限,一般都是nogroup(linux默认有),需要在/etc/group文
#件中有nogroup组
Group nogroup
#当服务器发生问题时发送报警的email地址,目前未用,注释掉
#ServerAdmin
root@localhost
#错误日志文件。如果没有以/开始,则表示从服务器的根路径开始。如果不需要错误日志,
则用#/dev/null。在下面设置时,注意一定要建立/var/log/boa目录
ErrorLog /var/log/boa/error_log
#访问日志文件。如果没有以/开始,则表示从服务器的根路径开始。如果不需要错误日志,
则用#/dev/null或直接注释掉。在下面设置时,注意一定要建立/var/log/boa目录
#AccessLog /var/log/boa/access_log
#是否使用本地时间。如果没有注释掉,则使用本地时间。注释掉则使用UTC时间【这个注释需要解开】
#UseLocaltime
#是否记录CGI运行信息,如果没有注释掉,则记录,注释掉则不记录
#VerboseCGILogs
#服务器名字【这个需要根据域名更改名字】
ServerName
www.
#是否启动虚拟主机功能,即设备可以有多个网络接口,每个接口都可以拥有一个虚拟的Web服
#务器。一般注释掉,即不需要启动
#VirtualHost
#非常重要,HTML文档的主目录。如果没有以/开始,则表示从服务器的根路径开始。
DocumentRoot /var/www
#如果收到一个用户请求的话,在用户主目录后再增加的目录名
UserDir public_html
#HTML目录索引的文件名,也是用户没有指定访问目录时返回的文件名
DirectoryIndex index.html
#当HTML目录没有索引文件时,用户只指明访问目录时,boa会调用该程序生成索引文件然后
#返回给用户,因为该过程比较慢最好不执行,可以注释掉或者给每个HTML目录加上#DirectoryIndex指明的文件
#DirectoryMaker /usr/lib/boa/boa_indexer
#如果DirectoryIndex不存在,并且DirectoryMaker被注释,那么就用Boa自带的索引
#生成程序来生成目录的索引文件并输出到下面目录,该目录必须是Boa能读写
# DirectoryCache /var/spool/boa/dircache
#一个连接所允许的HTTP持续作用请求最大数目,注释或设为0都将关闭HTTP持续作用
KeepAliveMax 1000
#HTTP持续作用中服务器在两次请求之间等待的时间数,以秒为单位,超时将关闭连接
KeepAliveTimeout 10
#指明mime.types文件位置。如果没有以/开始,则表示从服务器的根路径开始。可以注释掉
#避免使用mime.types文件,此时需要用AddType在本文件里指明
MimeTypes /etc/mime.types
#文件扩展名没有或未知的话,使用的缺省MIME类型
DefaultType text/plain
#提供CGI程序的PATH环境变量值
CGIPath /bin:/usr/bin:/usr/local/bin
#将文件扩展名和MIME类型关联起来,和mime.types文件作用一样。如果用mime.types
#文件,则注释掉,如果不使用mime.types文件,则必须使用
#AddType application/x-httpd-cgi cgi
#指明文档重定向路径
#Redirect /bar
http://elsewhere/feh/bar
#为路径加上别名
Alias /doc /usr/doc
#非常重要,指明CGI脚本的虚拟路径对应的实际路径。一般所有的CGI脚本都要放在实际路径
#里,用户访问执行时输入站点+虚拟路径+CGI脚本名【以下代码需要对比更改好!我为这句话没有更改查询了近1小时!!!!!!!!!!】
ScriptAlias /cgi-bin/ /var/www/cgi-bin/

用户可以根据自己需要,对boa.conf进行修改,但必须要保证其他的辅助文件和设置必须和boa.conf里的配置相符,不然Boa就不能正常工作。 在上面的例子中,我们还需要创建日志文件所在目录/var/log/boa,创建HTML文档的主目录/var/www,将mime.types文件拷贝 到/etc目录,创建CGI脚本所在目录/var/www/cgi-bin/。mime.types文件用来指明不同文件扩展名对应的MIME类型,一般 可以直接从Linux主机上拷贝一个,大部分也都是在主机的/etc目录下。


===================host test=======================================
1.进入 boa-0.94.13/src
 ./configure
 make
2.在etc/下建立boa目录并将boa.conf拷贝到该目录下.更改boa.conf
3.在 /var/log/下建立boa目录,该目录下可以查看boa服务器的日志。
4.其它的一些路径
默认是/var/www下的内容可以访问                       (DocumentRoot /var/www)
默认cgi :ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/  (cgi可执行程序放在 /usr/lib/cgi-bin/目录下)
 例子
http://201.201.201.249/cgi-bin/cgi-test.cgi
CGIPath /bin:/usr/bin:/usr/local/bin
只有这些目录下的命令可以被调用,如果要root的权限(如ifconfig配置ip)需要加上/sbin
5.将下面的cig例子中pass.c复制到记事本中存为pass.c,编译成pass,去除调试信息(strip),保存到www/cgi-bin/目录下。pass.html复制到记事本中存为pass.html。拷贝到/var/www目录下(注意如果用开发板,拷贝到相应文件系统的/var/www目录下)。
6.开发板上没有nobody用户,没有nogroup用户组,需要自行建立(建立nobody用户时会提示出错信息说没有/home/nobody目录,不必理会,因为我们不是用这个用户登录系统)。
#adduser nobody
#addgroup nogroup
7.拷贝boa可执行程序到文件系统的相应目录下。比如自行建立/boawebserver目录。运行./boa
8.windows中打开浏览器输入:192.168.1.10/pass.html,输入任意用户名和密码,登录后出现反馈信息即为成功。


=====================================================================
cgi例子
=====================================================================

/*********pass.c************/

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

char* getcgidata(FILE* fp, char* requestmethod);
int main()
{
       char *input;
       char *req_method;
       char name[64];
       char pass[64];
       int i = 0;
       int j = 0;
      
//     printf("Content-type: text/plain; charset=iso-8859-1\n\n");
       printf("Content-type: text/html\n\n");
       printf("The following is query reuslt:<br><br>");

       req_method = getenv("REQUEST_METHOD");
       input = getcgidata(stdin, req_method);

       // 我们获取的input字符串可能像如下的形式
       // Username="admin"&Password="aaaaa"
       // 其中"Username="和"&Password="都是固定的
       // 而"admin"和"aaaaa"都是变化的,也是我们要获取的
      
       // 前面9个字符是UserName=
       // 在"UserName="和"&"之间的是我们要取出来的用户名
       for ( i = 9; i < (int)strlen(input); i++ )
       {
              if ( input[i] == '&' )
              {
                     name[j] = '\0';
                     break;
              }                  
              name[j++] = input[i];
       }

       // 前面9个字符 + "&Password="10个字符 + Username的字符数
       // 是我们不要的,故省略掉,不拷贝
       for ( i = 19 + strlen(name), j = 0; i < (int)strlen(input); i++ )
       {
              pass[j++] = input[i];
       }
       pass[j] = '\0';

       printf("Your Username is %s<br>Your Password is %s<br> \n", name, pass);
      
       return 0;
}

char* getcgidata(FILE* fp, char* requestmethod)
{
       char* input;
       int len;
       int size = 1024;
       int i = 0;
      
       if (!strcmp(requestmethod, "GET"))
       { //从这里可以看出来,GET在cgi中传递的Username="admin"&Password="aaaaa"被放置在环境变量QUERY_STRING中了。
              input = getenv("QUERY_STRING");
              return input;
       }
       else if (!strcmp(requestmethod, "POST"))
       {
              len = atoi(getenv("CONTENT_LENGTH"));
              input = (char*)malloc(sizeof(char)*(size + 1));
             
              if (len == 0)
              {
                     input[0] = '\0';
                     return input;
              }
             
              while(1)
              { //从这里可以看出来,POST在cgi中传递的Username="admin"&Password="aaaaa"被写入stdin标准输入流中了。
                     input[i] = (char)fgetc(fp);
                     if (i == size)
                     {
                            input[i+1] = '\0';
                            return input;
                     }
                    
                     --len;
                     if (feof(fp) || (!(len)))
                     {
                            i++;
                            input[i] = '\0';
                            return input;
                     }
                     i++;
                    
              }
       }
       return NULL;
}
 
/*
*  gcc -o pass.cgi pass.c
*/

<!--pass.html-->
<html>
<head><title>用户登陆验证</title></head>
<body>
<!--下面的action是表单提交后在服务器端执行的gic程序(即c的可执行程序)-->
<!--cgi可执行程序放在 /usr/lib/cgi-bin/目录下-->
<form name="form1" action="/cgi-bin/pass.cgi" method="POST">
<table align="center">
    <tr><td align="center" colspan="2"></td></tr>
    <tr>
       <td align="right">用户名</td>
       <td><input type="text" name="Username"></td>
    </tr>
    <tr>
       <td align="right">密  码</td>
       <td><input type="password" name="Password"></td>
    </tr>
    <tr>
       <td><input type="submit" value="登  录"></td>
       <td><input type="reset" value="取  消"></td>
    </tr>
</table>
</form>
</body>
</html>


****************************************************
摘自:
http://blog./u1/33226/showart_485155.html
****************************************************

 


****************************************************
摘自:
http://hi.baidu.com/jiaolingqi/blog/item/3fb63a9ba776cdb4c9eaf4b5.html
****************************************************

C语言提供了几个标准库函数,可以将任意类型(整型、长整型、浮点型等)的数字转换为字符串。以下是用itoa()函数将整数转 换为字符串的一个例子:

# include <stdio.h>
# include <stdlib.h>

void main (void)
{
int num = 100;
char str[25];
itoa(num, str, 10);
printf("The number 'num' is %d and the string 'str' is %s. \n" ,
num, str);
}

itoa()函数有3个参数:第一个参数是要转换的数字,第二个参数是要写入转换结果的目标字符串,第三个参数是转移数字时所用 的基数。在上例中,转换基数为10。10:十进制;2:二进制...
itoa并不是一个标准的C函数,它是Windows特有的,如果要写跨平台的程序,请用sprintf。
是Windows平台下扩展的,标准库中有sprintf,功能比这个更强,用法跟printf类似:
char str[255];
sprintf(str, "%x", 100); //将100转为16进制表示的字符串。

下列函数可以将整数转换为字符串:
----------------------------------------------------------
函数名 作 用
----------------------------------------------------------
itoa() 将整型值转换为字符串
itoa() 将长整型值转换为字符串
ultoa() 将无符号长整型值转换为字符串

一  atoi     把字符串转换成整型数

例程序:

#include <ctype.h>
#include <stdio.h>
int atoi (char s[]);

int main(void )
{  

char s[100];

gets(s);

printf("integer=%d\n",atoi(s));
return 0;
}
int atoi (char s[])
{
int i,n,sign;

for(i=0;isspace(s[i]);i++)//跳过空白符
      ;
sign=(s[i]=='-')?-1:1;
if(s[i]=='+'||s[i]==' -')//跳过符号
      i++;
for(n=0;isdigit(s[i]);i++)
      n=10*n+(s[i]-'0');//将数字字符转换成整形数字
return sign *n;

}

二       itoa      把一整数转换为字符串

例程序:

#include <ctype.h>
#include <stdio.h>
void      itoa (int n,char s[]);
//atoi 函数:将s转换为整形数
int main(void )
{  
int n;
char s[100];

printf("Input n:\n");
scanf("%d",&n);

        printf("the string : \n");
        itoa (n,s);
return 0;
}
void itoa (int n,char s[])
{
int i,j,sign;

if((sign=n)<0)//记录符号
      n=-n;//使n成为正数
        i=0;
do{
      s[i++]=n%10+'0';//取下一个数字
}while ((n/=10)>0);//删除该数字

if(sign<0)
      s[i++]='-';
s[i]='\0';
for(j=i;j>=0;j--)//生成的数字是逆序的,所以要逆序输出
      printf("%c",s[j]);

}


 

 

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多