嵌入式web服务器boa移植全过程(含图解过程)

2023-11-08 13:18

本文主要是介绍嵌入式web服务器boa移植全过程(含图解过程),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、boa下载和安装:

1、修改编译安装文件:

1)在www.boa.org下载boa-0.94.13.tar.gz 并解压

2)在src目录下运行./configure生成Makefile。

3)生成Makefile文件,修改

CC = arm-linux-gcc -static

CPP = arm-linux-gcc –E -static

2、修改boa.c源文件

将boa.c文件中以下几行判断注释掉。

if (setuid(0) != -1) {
    DIE("icky Linux kernel bug!");
}

改为

/*if (setuid(0) != -1) {
    DIE("icky Linux kernel bug!");
}*/ 

大约211行附近

   /*  if (passwdbuf == NULL) {

            DIE("getpwuid");
        }
        if (initgroups(passwdbuf->pw_name, passwdbuf->pw_gid) == -1) {
            DIE("initgroups");
        }*/

 /*if (setuid(0) != -1) {
            DIE("icky Linux kernel bug!");
        }*/

3、修改文件compat.h

#define TIMEZONE_OFFSET(foo) foo##->tm_gmtoff
修改成
#define TIMEZONE_OFFSET(foo) (foo)->tm_gmtoff

4、执行#make 命令

#make

#arm-linux-strip boa  //去掉调试信息,生成的boa可执行文件将在70k左右。

将编译好的boa可执行文件拷贝到/bin目录 或者/sbin目录下。


二、配置boa.conf

配置只保留一下的文字(可以自己写一个boa.conf文件,同时保存相应的):

Port 80   //服务访问端口

User 0    //
Group 0   //

ErrorLog /var/log/boa/error_log //错误日志地址
AccessLog /var/log/boa/access_log  //访问日志文件

ServerName 192.168.*.* (开发板ip)

DocumentRoot /var/www  //HTML文档的主目录

UserDir public_html  //

DirectoryIndex index.html  //默认访问文件

DirectoryMaker /usr/lib/boa/boa_indexer

KeepAliveMax 1000   //一个连接所允许的HTTP持续作用请求最大数目

KeepAliveTimeout 10  //HTTP持续作用中服务器在两次请求之间等待的时间数,以秒为单位

MimeTypes /etc/mime.types  //指明mime.types文件位置

DefaultType text/plain  //文件扩展名没有或未知的话,使用的缺省MIME类型

CGIPath /bin:/usr/bin:/usr/local/bin   //提供CGI程序的PATH环境变量值

Alias /doc /usr/doc    //为路径加上别名

ScriptAlias /cgi-bin/ /var/www/cgi-bin/   //输入站点和CGI脚本位置

 

可以将以上的文档直接拷到一个空白的boa.conf文件中,并将boa.conf文件拷到/etc/boa/boa.conf位置。也可以修改源码包下的boa.conf

重点注意:

       用户可以根据自己需要,对boa.conf进行修改,但必须要保证其他的辅助文件和设置必须和boa.conf里的配置相符,不然Boa就不能正常工作。 在上面的例子中,我们还需要创建日志文件所在目录/var/log/boa,创建HTML文档的主目录/var/www。

       关键:将mime.types、inittab和passwd文件从任何一个linux系统中的/etc目录下拷贝到开发板文件系统的/etc目录下,创建CGI脚本所在目录/var/www/cgi-bin/。mime.types文件用来指明不同文件扩展名对应的MIME类型,一般可以直接从Linux主机上拷贝一个,大部分也都是在主机的/etc目录下。

这篇关于嵌入式web服务器boa移植全过程(含图解过程)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/370096

相关文章

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Springboot3统一返回类设计全过程(从问题到实现)

《Springboot3统一返回类设计全过程(从问题到实现)》文章介绍了如何在SpringBoot3中设计一个统一返回类,以实现前后端接口返回格式的一致性,该类包含状态码、描述信息、业务数据和时间戳,... 目录Spring Boot 3 统一返回类设计:从问题到实现一、核心需求:统一返回类要解决什么问题?

JavaWeb 中的 Filter组件详解

《JavaWeb中的Filter组件详解》本文详细介绍了JavaWeb中的Filter组件,包括其基本概念、工作原理、核心接口和类、配置方式以及常见应用示例,Filter可以实现请求预处理、响应后... 目录JavaWeb 中的 Filter 详解1. Filter 基本概念1.1 什么是 Filter1.

JAVA SpringBoot集成Jasypt进行加密、解密的详细过程

《JAVASpringBoot集成Jasypt进行加密、解密的详细过程》文章详细介绍了如何在SpringBoot项目中集成Jasypt进行加密和解密,包括Jasypt简介、如何添加依赖、配置加密密钥... 目录Java (SpringBoot) 集成 Jasypt 进行加密、解密 - 详细教程一、Jasyp

Java通过ServerSocket与Socket实现通信过程

《Java通过ServerSocket与Socket实现通信过程》本文介绍了Java中的ServerSocket和Socket类,详细讲解了它们的构造方法和使用场景,并通过一个简单的通信示例展示了如何... 目录1 ServerSocket2 Socket3 服务器端4 客户端5 运行结果6 设置超时总结1

Linux服务器数据盘移除并重新挂载的全过程

《Linux服务器数据盘移除并重新挂载的全过程》:本文主要介绍在Linux服务器上移除并重新挂载数据盘的整个过程,分为三大步:卸载文件系统、分离磁盘和重新挂载,每一步都有详细的步骤和注意事项,确保... 目录引言第一步:卸载文件系统第二步:分离磁盘第三步:重新挂载引言在 linux 服务器上移除并重新挂p

Apache服务器IP自动跳转域名的问题及解决方案

《Apache服务器IP自动跳转域名的问题及解决方案》本教程将详细介绍如何通过Apache虚拟主机配置实现这一功能,并解决常见问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录​​问题背景​​解决方案​​方法 1:修改 httpd-vhosts.conf(推荐)​​步骤

java对接Pinata上传文件到IPFS全过程

《java对接Pinata上传文件到IPFS全过程》本文详细介绍了如何使用PinataAPI将文件上传到IPFS网络,首先登录Pinata官网并生成JWT令牌,然后在项目中导入OkHttp依赖并编写代... 目录1.登录2.生成令牌3.导入依赖4.编写代码5.调用接口调试China编程代码总结Pinata调用AP

MongoDB搭建过程及单机版部署方法

《MongoDB搭建过程及单机版部署方法》MongoDB是一个灵活、高性能的NoSQL数据库,特别适合快速开发和大规模分布式系统,本文给大家介绍MongoDB搭建过程及单机版部署方法,感兴趣的朋友跟随... 目录前言1️⃣ 核心特点1、文档存储2、无模式(Schema-less)3、高性能4、水平扩展(Sh

MySQL中存储过程(procedure)的使用及说明

《MySQL中存储过程(procedure)的使用及说明》存储过程是预先定义的SQL语句集合,可在数据库中重复调用,它们提供事务性、高效性和安全性,MySQL和Java中均可创建和调用存储过程,示例展... 目录概念示例1示例2总结概念存储过程:在数据库中预先定义好一组SQL语句,可以被程序反复调用。