当前位置: 首页 > 编程日记 > 正文

linux独立应用程序开发,Linux应用程序开发(一)

Linux应用程序开发(一)---移植thttpd+Sqlite3+PHP5到arm linux(4)

移植环境(红色粗字体字为修改后内容,蓝色粗体字为特别注意内容)

1,主机环境:VMare下CentOS 5.5 ,1G内存。

2,集成开发环境:Elipse IDE

3,编译编译环境:arm-linux-gcc v4.4.3,arm-none-linux-gnueabi-gcc v4.5.1。

4,开发板:mini2440,2M nor flash,128M nand flash。

5,u-boot版本:u-boot-2009.08

6,linux 版本:linux-2.6.32.2

7,参考文章:

接上篇

【16】在开发板终端进行测试

(1)创建数据库文件test.db

[root@mini2440 /]#cd /home/www

#sqlite3 test.db

SQLite version 3.7.7.1 2011-06-28 17:39:05

Enter ".help" for instructions

Enter SQL statements terminated with a ";"

sqlite>

(2)创建表

sqlite> create table students(id integer,name text,age integer);

sqlite> .tables

students

sqlite>

(3)删除表

sqlite> drop table students

sqlite> .tables

sqlite>

(4)查看表结构

sqlite> create table students(id integer,name text,age integer);

sqlite> .schema students

CREATE TABLE students(id integer,name text,age integer);

sqlite>

(5)插入列

sqlite> alter table students add cul;

sqlite> alter table students add column sex text;

sqlite> .schema students

CREATE TABLE students(id integer,name text,age integer, cul, sex text);

sqlite>

(6)插入表记录

sqlite> insert into students values(1,'aa',10,0,'m');

sqlite> insert into students values(2,'bb',11,1,'f');

sqlite> select * from students;

1|aa|10|0|m

2|bb|11|1|f

sqlite>

(7)重命名表

sqlite> alter table students rename to stu;

sqlite>

(8)删除某一列,这为列cul

sqlite> begin transaction;

sqlite> create temporary table stu_bak(id integer,name text,age integer,sex text);

sqlite> insert into stu_bak select id,name,age,sex from stu;

sqlite> drop table stu;

sqlite> create table stu(id integer,name text,age integer,sex text);

sqlite> insert into stu select id,name,age,sex from stu_bak;

sqlite> drop table stu_bak;

sqlite> select * from stu;

1|aa|10|m

2|bb|11|f

sqlite> commit;

sqlite>

(9)退出程序

sqlite> .quit

[root@mini2440 www]#

sqlite数据库操作测试

【17】在C代码中进行操作测试

这里以SQLite官方站点http://sqlite.org的quick start文档中的测试程序为例对移植到ARM-Linux上的SQLite3进行测试。该程序清单如下:

//test_sqlite.c

#include

#include

#include

static int callback(void *NotUsed, int argc, char **argv, char **azColName)

{

int i;

for(i=0; i

{

printf("%s = %s\n", azColName[i], argv [i]);

}

printf("\n");

return 0;

}

int main(int argc, char **argv)

{

sqlite3 *db;

char *zErrMsg = 0;

int rc;

if( argc!=3 )

{

fprintf(stderr, "Usage: %s DATABASE SQL-STATEMENT\n", argv[0]);

}

rc = sqlite3_open(argv[1], &db);

if( rc )

{

fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));

sqlite3_close(db);

}

rc = sqlite3_exec(db, argv[2], callback, 0, &zErrMsg);

if( rc!=SQLITE_OK )

{

fprintf(stderr, "SQL error: %s\n", zErrMsg);

}

sqlite3_close(db);

return 0;

}

使用如下命令编译测试程序:

交叉编译时采用arm-linux-gcc -I /……(安装路径)/include -L/……(安装路径)/lib -o target src -lsqlite3

arm-linux-gcc -o test_sqlite test_sqlite.c -lsqlite3 -L /nfsboot/rootfs/usr/local/lib/ -I /nfsboot/rootfs/usr/local/include/

3、在上面新建的数据库目录下测试:

[root@mini2440 www]#./test_sqlite test.db "select * from stu"

id = 1

name = aa

age = 10

sex = m

id = 2

name = bb

age = 11

sex = f

[root@mini2440 www]#

【18】在php代码中进行操作测试

thttpd+Sqlite3+PHP5综合测试

(1)访问权限修改

开发板/home/www/html目录下的测试文件目前只有root用户有访问权限,而客户是以www用户身份进行访问的,因此需要让www用户也具有访问权限

[root@mini2440 /]#chmod a+rx /home/www/html/test.php

[root@mini2440 /]#

test.php的内容如下:

dl('sqlite3.so');

$dbh = new PDO('sqlite:test.db');

if ($dbh)

{

$dbh->beginTransaction();

$sth = $dbh->prepare('select * from stu');

$sth->execute();

$result = $sth->fetchAll();

print_r($result);

}

else

{

echo "Err \n";

}

?>

在浏览器中键入开发板IP地址http://10.1.0.129/test.php,显示内容如下:

Array ( [0] => Array ( [id] => 1 [0] => 1 [name] => aa

[1] => aa [age] => 10 [2] => 10 [sex] => m [3] => m ) [1]

=> Array ( [id] => 2 [0] => 2 [name] => bb [1] => bb

[age] => 11 [2] => 11 [sex] => f [3] => f ) )

终于在浏览器中看到了数据库test.db中的内容。这说明 thttpd+Sqlite3+PHP5已经在正常工作了。

【19】在php中安装pear扩展库

安装pear需要使用php命令来执行一个go-pear.php的文件来完成:

将整个网页内容复制下来并存储为go-pear.php即可。

我们这里可以使用vim命令建立go-pear.php文件,将内容复制进去,保存,增加执行权限即可。

在开发板终端用php命令执行go-pear.php:

[root@mini2440 /]#/usr/local/bin/php go-pear.php

PHP Warning:  Module 'PDO' already loaded in Unknown on line 0

PHP Warning:  Module 'pdo_sqlite' already loaded in Unknown on line 0

PHP Warning:  Module 'SQLite' already loaded in Unknown on line 0

Could not open input file: go-pear.php

出现上面错误的原因是,外部动态库加载有两种方式,一种是通过编译指定 -ldl

将外部extension目录直接编译进php,另一种是通过php的ini文件指定,这里的错误指示出外部动态链接库已经被编译进php了,还在

php.ini指定,因而出错。打开php.ini文件,注释到下面几行(参考http://www.somacon.com/p520.php)

; Directory in which the loadable extensions (modules) reside.

extension_dir = "/usr/local/lib/php/extensions/no-debug-non-zts-20060613"

;extension=pdo.so

;extension=pdo_sqlite.so

;extension=sqlite.so

然后再开发板终端用php命令执行go-pear.php:

[root@mini2440 /]#/usr/local/bin/php go-pear.php

Could not open input file: go-pear.php

[root@mini2440 /]#

遗留问题:如何在交叉安装php的pear扩展库。

接下来,让PHP5支持java在arm linux运行

相关文章:

面向过程(结构化)分析方法与面向对象分析方法的区别

面向过程是从问题的总体目标开始,抽象底层的细节,先专心构造高层的结构,然后再一层一层地分解合细化。 面向对象则是运用对象、类、继承、封装、聚合、消息传递、多态性等概念来构造系统的方法。 面向过程着重于解决问题的从粗略到详尽的方法…

eclipse.ini内存设置

-vmargs -Xms128M -Xmx512M -XX:PermSize64M -XX:MaxPermSize128M 这里有几个问题:1. 各个参数的含义什么?2. 为什么有的机器我将-Xmx和-XX:MaxPermSize都设置为512M之后Eclipse可以启动,而有些机器无法启动?3. 为何将上面的参数写…

如何运用下载来的模板

(1)在相应的网址下载模块文件 例如:https://github.com/yagitoshiro/ImageAsResized (2)把下载的模块包解压放到C:\Users\Administrator\AppData\Roaming\Titanium\modules\android 目录结构如下所示: 而这…

红旗linux桌面版反应慢,红旗Linux6.0桌面版使用感受

1.红旗Linux6.0桌面版中文支持比较好,毕竟是国人出的发行版;输入法很不错;自动挂载win分区(好像Ubuntu、OpenSUSE、Fedora等这些流行发行版的新版都支持了),自动安装网络,用路由的话可以直接上网了。2.处处向windows靠…

device.cpp

Java代码 #include "device.h" #include <math.h> //Class Timer member function implementation int Timer::createTimer() { _start 0; _clocks 0; #ifdef _WIN32 QueryPerformanceFrequency((LARGE_INTEGER* )&_freq); #else _freq (long long)1.0E…

简明python教程 --C++程序员的视角(九):函数式编程、特殊类方法、测试及其他...

函数式编程 Lambda exec&#xff0c;eval和assert语句&#xff0c;repr函数 lambda语句 用来创建简短的单行匿名函数 print_assign lambda name, value: name str(value)等同于def print_assign(name, value): return name str(value) lambda需要一个参数&#xf…

防止重复提交订单-(转)

防止重复提交 Button1.Attributes.Add("onclick", "this.value正在提交中&#xff0c;请等待……;this.disabledtrue;" this.GetPostBackEventReference(Button1)); 于是根据这个写了个只能提交一次的控件&#xff1a; publicclassButtonSubmitOn…

linux pps 包 网卡,linux下安装PPS

到官方下载FEDORA版RPM包。[talenliangshan Downloads]$ sudo yum localinstall PPStream.rpm已加载插件&#xff1a;axelget, fastestmirror, presto, priorities, refresh-packagekit, remove-with-leaves设置本地安装进程诊断 PPStream.rpm: PPStream-1.0.2-11.i386PPStream…

C#设置本地网络(DNS、网关、子网掩码、IP)

如今网络在我们的生活工作中所起的作用越来越大&#xff0c;可以说离开了网络我们就无法正常的工作和生活。作为程序员我们写的程序大多数也会跟网络相关&#xff0c;而想要使用网络首先要将机器的网络配置设置好。而手动设置的方法显然很不可取&#xff0c;所以我们要让程序帮…

Dynamics CRM2016 Web API之创建记录

前篇介绍了通过primary key来查询记录&#xff0c;那query的知识点里面还有很多需要学习的&#xff0c;这个有待后面挖掘&#xff0c;本篇来简单介绍下用web api的创建记录。 直接上代码&#xff0c;这里的entity的属性我列了几个比较典型的&#xff0c;和原来相比有区别的是选…

bootstrap轮播如何支持移动端滑动手势

1.下载滑动手势 js 插件&#xff1a;hammer.js //cdn.bootcss.com/hammer.js/2.0.8/hammer.min.js 2.写一个javascript命令调用hammer.js中的swipe功能 <script>$(function(){//添加移动端滑动var myElement document.getElementById(myCarousel)//id为轮播的idvar hmnew…

linux程序计数器,如何在C中打印程序计数器的确切值

小编典典您应该能够使用ARM编译器工具链中的__current_pc()内在函数来确定PC(ARM编译器支持许多与GCC相同的扩展)。*这是ARM特有的&#xff1a;int main () {printf("%#x\n", __current_pc());printf("%#x\n", __current_pc());printf("%#x\n", …

『转载』Debussy快速上手(Verdi相似)

『转载』Debussy快速上手&#xff08;Verdi相似&#xff09; Debussy 是NOVAS Software, Inc(思源科技)发展的HDL Debug & Analysis tool&#xff0c;这套软体主要不是用来跑模拟或看波形&#xff0c;它最强大的功能是&#xff1a;能够在HDL source code、schematic diagra…

大家好,新年快乐。

刚申请了个博客&#xff0c;祝大家新年快乐。 &#xff0d;&#xff0d;&#xff0d;&#xff0d;&#xff0d;&#xff0d;&#xff0d;&#xff0d;&#xff0d;&#xff0d;&#xff0d;&#xff0d;&#xff0d; So many children are playing zhu zhu pets at home.This t…

maven项目找不到pom.xml配置的dependency jar中的类问题解决方法

成功创建一个web项目后&#xff0c;假如我们在web.xml文件中&#xff0c;配置了spring的listener&#xff0c;在pom.xml中也已经作了依赖配置。部署 完项目后&#xff0c;启动项目&#xff0c;发现找不到spring配置的listner 类&#xff1a;org.springframework.web.context.Co…

红旗linux yum,更换红旗Linux: Asianux的yum源为网易源

测试环境&#xff1a;Linux系统版本Asianux4_x64&#xff1a;Linux localhost.localdomain 2.6.32-279.2.1.el6.x86_64 #1 SMP Tue Aug 14 11:42:24 CST 2012 x86_64 x86_64 x86_64 GNU/Linux本质上Asianux4_x64就是基于Redhat6企业版的。出现问题&#xff1a;安装完系统之后&a…

Java Socket编程 - 基于TCP方式的二进制文件传输【转】http://blog.csdn.net/jia20003/article/details/8248221...

此人博客挺好的&#xff0c;推荐一个&#xff01; 一个基于Java Socket协议之上文件传输的完整示例&#xff0c;基于TCP通信完成。 除了基于TCP的二进制文件传输&#xff0c;还演示了JAVA Swing的一些编程技巧&#xff0c;Demo程序 实现主要功能有以下几点&#xff1a; 1. …

SuSE下VNCVIEWER没有出现界面,只有shell窗口的问题

首先正确配置&#xff0c;打开vncserver &#xff1a;1&#xff0c;实际上有三个服务&#xff0c;vnc1&#xff0c;vnc2&#xff0c;vnc3&#xff0c;对应着三个服务&#xff0c;先打开。 可以直接在shell下输入 #vncserver :1.也可以使用界面打开Network Service (xinetd),将服…

docker容器互联

link方式 http://blog.csdn.net/halcyonbaby/article/details/42112325 通过link方式创建容器&#xff0c;然后我们可以使用被link容器的别名进行访问。从而解除应用对IP的依赖。不幸的是,link方式只能解决单机容器间的互联。多机情况下&#xff0c;容器的互联需要其他的方式。…

glib 2.0 arm linux,glib源码安装使用方法

glib库是GTK和GNOME工程的基础底层核心程序库&#xff0c;是一个综合用途的实用的轻量级的C程序库&#xff0c;它提供C语言的常用的数据结构的定义、相关的处理函数&#xff0c;有趣而实用的宏&#xff0c;可移植的封装和一些运行时机能&#xff0c;如事件循环、线程、动态调用…

iOS 用自签名证书实现 HTTPS 请求的原理实例讲解

在16年的WWDC中&#xff0c;Apple已表示将从2017年1月1日起&#xff0c;所有新提交的App必须强制性应用HTTPS协议来进行网络请求。默认情况下非HTTPS的网络访问是禁止的并且不能再通过简单粗暴的向Info.plist中添加NSAllowsArbitraryLoads设置绕过ATS(App Transport Security)的…

WordPress Editorial Calendar插件权限安全绕过漏洞

漏洞名称&#xff1a;WordPress Editorial Calendar插件权限安全绕过漏洞CNNVD编号&#xff1a;CNNVD-201302-369发布时间&#xff1a;2013-02-22更新时间&#xff1a;2013-02-22危害等级&#xff1a; 漏洞类型&#xff1a;权限许可和访问控制威胁类型&#xff1a;远程CVE编号…

文件操作(ifstream、ofstream、fstream)

原文链接&#xff1a;http://blog.csdn.net/soar_ersa/article/details/3908943 转载于:https://www.cnblogs.com/MrYuan/p/5288264.html

linux error log 换行,日志提示

日志提示线上问题&#xff0c;需要看日志。控制台可以打印Mybatis操作的SQL语句。开发流程&#xff1a;第一步&#xff1a;加入依赖image.png第二步&#xff1a;在项目的resources中加入log4j属性文件image.png第三步&#xff1a;演示image.png扩展了解一、日志概念的介绍Log4j…

本页面添加至收藏夹

经常在网站页面上需要把本页面添加至收藏夹 <script type"text/javascript">function addMe() {var url document.location.href;var wTitle document.title;if (document.all) {window.external.addFavorite(url, wTitle);} else if (window.sidebar) {wind…

javascript——Array类型

今天这节教程不仅仅是阐述ECMAScript3的部分功能&#xff0c;同时也会阐述有关EXMASctip5的很多新的功能。 一、创建 因为它是一个引用类型&#xff0c;自然就需要在使用前先构造它。 我将分成两种方式来讲述 I、构造函数 1.空的Array实例 var colors new Array(); 2.初始化存…

iOS使用自签名证书实现HTTPS请求

原文链接:http://www.jianshu.com/p/e6a26ecd84aa 由于苹果规定2017年1月1日以后&#xff0c;所有APP都要使用HTTPS进行网络请求&#xff0c;否则无法上架&#xff0c;因此研究了一下在iOS中使用HTTPS请求的实现。相信大家对HTTPS都或多或少有些了解&#xff0c;这里我就不再介…

蜜蜂实训平台c语言考试答案,北理c语言上机答案(全)

小蜜蜂的不过,麻烦大家上百度找一下~1 Hello world让我们用C语言向世界问好。 最早的程序基本是这个样子的&#xff1a; 程序一&#xff1a;#include void main() {printf("Hello world.\n"); }程序二&#xff1a;#include int main() {printf("Hello world.\n&…

ecshop目录结构

ECShop 最新程序 的结构图及各文件相应功能介绍ECShop文件结构目录┣ activity.php 活动列表┣ affiche.php 广告处理文件┣ affiliate.php 生成商品列表┣ article.php 文章内容┣ article_cat.php文章分类┣ auction.php 拍卖前台文件┣ brand.php 品牌列表┣ captcha.php 生…

一劳永逸,iOS 网页视图控制器通用类封装

原文链接&#xff1a;http://www.jianshu.com/p/553424763585随着 H5 的发展&#xff0c;在 iOS 开发中&#xff0c;网页视图的使用率逐渐提升&#xff0c;为了增加代码封装度、减轻开发负担&#xff0c;因此通常会对网页视图进行通用类的封装&#xff0c;本文简单讲述网页视图…