busybox filesystem httpd php-5.5.31 sqlite3 webserver
/********************************************************************
* busybox filesystem httpd php-5.5.31 sqlite3 webserver
* 声明:
* 本文主要是记录使用httpd、php5、sqlite3搭建php web服务器。
*
* 2016-1-24 深圳 南山平山村 曾剑锋
*******************************************************************/ 一、参考文章:
. Run busybox httpd with php
https://box.matto.nl/busyboxphp.html
. Sqlite undefined reference to `sqlite3_open' error in Netbeans C++ on Ubuntu, Integrating SQLite into Netbeans C++ Ubuntu
http://stackoverflow.com/questions/3463438/sqlite-undefined-reference-to-sqlite3-open-error-in-netbeans-c-on-ubuntu-in
. 嵌入式WEB服务器移植三部曲之PHP的移植
http://blog.csdn.net/cos_sin_tan/article/details/7734278
. Real210 编译sqlite错误:.//libsqlite3.a(sqlite3.o): In function `unixDlSym’:
http://www.jyguagua.com/?p=965
. 成功移植SQLite3到ARM Linux开发板
http://www.myir-tech.com/bbs/thread-6189-1-1.html
. ARM上linux终端操作SQLITE,退格键问题
http://www.programgo.com/article/61872541163/
. 用busybox做一个简单的文件系统
http://blog.chinaunix.net/uid-9688646-id-3346880.html
. Using SQLite3 with PHP
http://babbage.cs.qc.cuny.edu/courses/cs903/2013_02/using_sqlite3.html 二、测试busybox httpd:
. cat /www/index.html
<h1>Welcome to Tinyfs</h1>
<p>zengjf</p>
. shell命令:/usr/sbin/httpd -vv -f -h /www/
. 查看ARM板IP:
[zengjf@root www]# ifconfig eth0
eth0 Link encap:Ethernet HWaddr 1E:ED:::1A:B3
inet addr:10.0.1.52 Bcast:10.0.1.255 Mask:255.255.255.0
UP BROADCAST RUNNING MULTICAST MTU: Metric:
RX packets: errors: dropped: overruns: frame:
TX packets: errors: dropped: overruns: carrier:
collisions: txqueuelen:
RX bytes: (4.8 KiB) TX bytes: (3.9 KiB) [zengjf@root www]#
. PC机浏览器访问:http://10.0.1.52/
经验证获取到了正确信息,Vim里贴不上图,就不贴图了。
. shell响应如下:
[zengjf@root www]# /usr/sbin/httpd -vv -f -h /www/
10.0.1.50:: url:/
10.0.1.50:: response:
三、编译、安装、测试php-5.5.
. ./configure -host=arm-linux-gnueabihf -prefix=/usr/local/php -disable-all -enable-pdo -with-sqlite3 -with-sqlite -with-pdo-sqlite -with-zlib -without-iconv
. make
. 错误
ext/sqlite3/libsqlite/sqlite3.o: In function `unixDlError':
/home/Qt/rootfs/busybox/php/php-5.5./ext/sqlite3/libsqlite/sqlite3.c:: undefined reference to `dlerror'
ext/sqlite3/libsqlite/sqlite3.o: In function `unixDlClose':
/home/Qt/rootfs/busybox/php/php-5.5./ext/sqlite3/libsqlite/sqlite3.c:: undefined reference to `dlclose'
ext/sqlite3/libsqlite/sqlite3.o: In function `unixDlSym':
/home/Qt/rootfs/busybox/php/php-5.5./ext/sqlite3/libsqlite/sqlite3.c:: undefined reference to `dlsym'
ext/sqlite3/libsqlite/sqlite3.o: In function `unixDlOpen':
/home/Qt/rootfs/busybox/php/php-5.5./ext/sqlite3/libsqlite/sqlite3.c:: undefined reference to `dlopen'
collect2: error: ld returned exit status
make: *** [sapi/cli/php] Error
. 解决方法:
修改Makefile中的:
EXTRA_LIBS = -lcrypt -lcrypt -lrt -lz -lm -lcrypt -lcrypt
为:
EXTRA_LIBS = -lcrypt -lcrypt -lrt -lz -lm -lcrypt -lcrypt -ldl
. 效果:
end_closures.lo Zend/zend_float.lo Zend/zend_string.lo Zend/zend_signal.lo Zend/zend_generators.lo Zend/zend_objects.lo Zend/zend_object_handlers.lo Zend/zend_objects_API.lo Zend/zend_default_classes.lo Zend/zend_execute.lo main/internal_functions_cli.lo sapi/cgi/cgi_main.lo sapi/cgi/fastcgi.lo -lcrypt -lcrypt -lrt -lz -lm -lcrypt -lcrypt -ldl -o sapi/cgi/php-cgi Build complete.
Don't forget to run 'make test'.
. sudo make install
. 拷贝PC机/usr/local/php目录下文件到:<filesystem root>/usr/local/php
. 配置httpd.conf:
cat /etc/httpd.conf
*.php:/usr/local/php/bin/php-cgi
. cat /www/test.php
<?
phpinfo();
?>
. PC机浏览器访问:http://10.0.1.52/test.php
. 报错现象:
This PHP CGI binary was compiled with force-cgi-redirect enabled. This means that a page will only be served up if the REDIRECT_STATUS CGI variable is set, e.g. via an Apache Action directive.
For more information as to why this behaviour exists, see the manual page for CGI security.
For more information about changing this behaviour or re-enabling this webserver, consult the installation file that came with this distribution, or visit the manual page.
. 解决办法:
将force-cgi-redirect设置disable。
. 查看php.ini位置:
[zengjf@root /usr/local/php/bin]# ./php-cgi -i | grep ini
<tr><td class="e">Configuration File (php.ini) Path </td><td class="v">/usr/local/php/lib </td></tr>
<tr><td class="e">Loaded Configuration File </td><td class="v">/usr/local/php/lib/php.ini </td></tr>
<tr><td class="e">Scan this dir for additional .ini files </td><td class="v">(none) </td></tr>
<tr><td class="e">Additional .ini files parsed </td><td class="v">(none) </td></tr>
<tr><td class="e">user_ini.cache_ttl</td><td class="v"></td><td class="v"></td></tr>
<tr><td class="e">user_ini.filename</td><td class="v">.user.ini</td><td class="v">.user.ini</td></tr>
<tr><td class="e">Classes </td><td class="v">AppendIterator, ArrayIterator, ArrayObject, BadFunctionCallException, BadMethodCallException, CachingIterator, CallbackFilterIterator, DirectoryIterator, DomainException, EmptyIterator, FilesystemIterator, FilterIterator, GlobIterator, InfiniteIterator, InvalidArgumentException, IteratorIterator, LengthException, LimitIterator, LogicException, MultipleIterator, NoRewindIterator, OutOfBoundsException, OutOfRangeException, OverflowException, ParentIterator, RangeException, RecursiveArrayIterator, RecursiveCachingIterator, RecursiveCallbackFilterIterator, RecursiveDirectoryIterator, RecursiveFilterIterator, RecursiveIteratorIterator, RecursiveRegexIterator, RecursiveTreeIterator, RegexIterator, RuntimeException, SplDoublyLinkedList, SplFileInfo, SplFileObject, SplFixedArray, SplHeap, SplMinHeap, SplMaxHeap, SplObjectStorage, SplPriorityQueue, SplQueue, SplStack, SplTempFileObject, UnderflowException, UnexpectedValueException </td></tr>
. 配置php.ini:
cat /usr/local/php/lib/php.ini
cgi.force_redirect =
cgi.redirect_status_env ="yes";
. PC机浏览器访问:http://10.0.1.52/test.php
经验证获取到了正确信息,Vim里贴不上图,就不贴图了。
. shell响应如下:
[zengjf@root /usr/local/php/lib]# /usr/sbin/httpd -vv -f -h /www/
10.0.1.50:: url:/
10.0.1.50:: response:
10.0.1.50:: url:/test.php 四、编译、安装、测试sqlite3:
. ./configure --host=arm-linux-gnueabihf --prefix=/usr/local/sqlite
. make
. sudo make install
. 报错:
libtool: install: /usr/bin/install -c .libs/libsqlite3.a /usr/local/sqlite/lib/libsqlite3.a
libtool: install: chmod /usr/local/sqlite/lib/libsqlite3.a
libtool: install: arm-linux-gnueabihf-ranlib /usr/local/sqlite/lib/libsqlite3.a
./libtool: line : arm-linux-gnueabihf-ranlib: command not found
make[]: *** [install-libLTLIBRARIES] Error
make[]: Leaving directory `/home/Qt/rootfs/busybox/sqlite/sqlite-autoconf-'
make: *** [install-am] Error
. 解决方法:
是由于使用了sudo,导致环境变丢失,用su切换到root用户,再重新设置环境变量来解决。
. 拷贝/usr/local/sqlite中的文件到<filesystem root>下对应的目录。
. 建立软链接:ln -s /bin/sqlite3 /bin/sqlite
. 不能使用退格键(backspace):
. 错误现象:
[zengjf@root ~]# sqlite
SQLite version 3.10. -- ::
Enter ".help" for usage hints.
Connected to a transient in-memory database.
Use ".open FILENAME" to reopen on a persistent database.
sqlite> shw^H^H^H^H^H
. 解决方法:
终端执行shell命令:stty erase ^H
. 在ARM板上运行效果如下:
[zengjf@root ~]# sqlite
SQLite version 3.10. -- ::
Enter ".help" for usage hints.
Connected to a transient in-memory database.
Use ".open FILENAME" to reopen on a persistent database.
sqlite> .show
echo: off
eqp: off
explain: off
headers: off
mode: list
nullvalue: ""
output: stdout
colseparator: "|"
rowseparator: "\n"
stats: off
width:
sqlite> .quit
[zengjf@root ~]#
. cat /www/teatdb.php
<?
$db = new SQLite3('my_database') or die('Unable to open database');
$query = <<<EOD
CREATE TABLE IF NOT EXISTS users (
username STRING PRIMARY KEY,
password STRING)
EOD; # 这里一定要顶格
$db->exec($query) or die('Create db failed');
$query = <<<EOD
INSERT INTO users VALUES ( 'zengjf', 'root' )
EOD; # 这里一定要顶格
$db->exec($query) or die("Unable to add user $user");
$result = $db->query('SELECT * FROM users') or die('Query failed');
while ($row = $result->fetchArray())
{
echo "User: {$row['username']}\nPasswd: {$row['password']}\n";
}
?>
. PC机浏览器访问:http://10.0.1.52/testdb.php
经验证获取到了正确信息,Vim里贴不上图,就不贴图了。
. shell响应如下:
[zengjf@root ~]#
127.0.0.1:: url:/
127.0.0.1:: response:
10.0.1.50:: url:/testdb.php
. 可能错误:
. Fatal error: Class 'SQLiteDatabase' not found in /www/testdb.php on line
. 这是由于移植的sqlite3,可能这里使用的是sqlite的接口,
使用sqlite3的接口可以避免这个错误。

busybox filesystem httpd php-5.5.31 sqlite3 webserver的更多相关文章
- busybox filesystem matrix-gui-2.0 undefined function json_encode()
/******************************************************************************** * matrix-gui-2.0 u ...
- busybox filesystem ifup
/******************************************************************** * busybox filesystem ifup * 声明 ...
- busybox filesystem udhcpc 原理
/******************************************************************** * busybox filesystem udhcpc 原理 ...
- busybox filesystem ts_config: No such file or directory
/******************************************************************** * busybox filesystem ts_config ...
- busybox filesystem add ldd function
/******************************************************************** * busybox filesystem add ldd f ...
- Run busybox httpd with php, sqlite
/*********************************************************************************** * Run busybox h ...
- 使用 linux kernel +busybox 定制linux系统
目的: 了解linux的启动过程 主要内容: 1.grub 是启动程序的bootloader 2.linux-kernel 是linux的开源内核 3.busybox 是linux的工具集合 启动顺序 ...
- 交叉编译Python-2.7.13到ARM(aarch32)—— 支持sqlite3
作者:彭东林 邮箱:pengdonglin137@163.com QQ: 405728433 环境 主机: ubuntu14.04 64bit 开发板: qemu + vexpress-a9 (参考: ...
- httpd在嵌入式中应用
在启动脚本合适位置添加: httpd -h /usr/app/www/ 即开始httpd服务,并定位到/usr/app/www/ 注:busybox已支持httpd命令,所以直接用即可. busybo ...
随机推荐
- CString向char类型转化 ---“=”: 无法从“wchar_t *”转换为“char *
此文从网上复制过来,原文出处已丢失,望见谅哈 VC 2005中,这个本来很简单的问题又稍微复杂了一点. 在工程里面,一个必不可少的步骤就是把CString转换为shar*字符串.通过 ...
- 01-08-05【Nhibernate (版本3.3.1.4000) 出入江湖】NHibernate二级缓存:第三方MemCache缓存
一.准备工作 [1]根据操作系统(位数)选择下载相应版本的MemCache, MemCache的下载和安装,参看: http://www.cnblogs.com/easy5weikai/p/37606 ...
- java 页面换行处理
在taxtarea中输入的文本.如果含有回车或空格.在界面上显示的时候则不哪么正常.回车消失了,空格变短了. 如何解决这个问题呢.有2种方法. 1.使用<pre>标签 w3c对pre元素是 ...
- oracle 表空间 用户
Oracle创建表空间.创建用户以及授权.查看权限 创建临时表空间 CREATE TEMPORARY TABLESPACE test_temp TEMPFILE 'C:\oracle\product\ ...
- 解谜谷歌 DevOps:什么特质可以打造世界级可靠系统?
[编者按]本文是 Gene Kim 总结自对 Randy Shoup 两个小时的采访,主要关注谷歌 DevOps 的提升之道.本文系 OneAPM联合高效运维编译整理. Randy Shoup 曾协助 ...
- 暑假集训单切赛第一场 CF 266E More Queries to Array(线段树+二项式展开式)
比赛时,第二题就是做的这个,当时果断没仔细考虑,直接用线段树暴力求.结果易想而知,超时了. 比赛后搜了搜题解,恍然大悟. 思路:显然用线段树,但是由于每次查询都会有变,所以不可能存储题目中的式子. ...
- 在mac上安装hadoop伪分布式
换了macbook pro之后,要重新安装hadoop,但是mac上的jdk跟windows上的不同,导致折腾了挺久的,现在分享出来,希望对大家有用. 一:下载jdk 选择最新版本下载,地址:http ...
- HDU 3507 Print Article(斜率优化DP)
题目链接 题意 : 一篇文章有n个单词,如果每行打印k个单词,那这行的花费是,问你怎么安排能够得到最小花费,输出最小花费. 思路 : 一开始想的简单了以为是背包,后来才知道是斜率优化DP,然后看了网上 ...
- lintcode :链表插入排序
题目: 链表插入排序 用插入排序对链表排序 样例 Given 1->3->2->0->null, return 0->1->2->3->null 解题: ...
- java小程序:求完全数
如果一个数等于它的不包括自身的所有因数之和,那么这个数就叫完全数.例如,6的不包括自身的所有因数为1,2,3,而且6=1+2+3,所以6是完全数. 大约2200多年前,欧几里德提出:如果2n-1是质数 ...