承接上一篇文章:《Python2.5.4移植到arm-linux》
http://blog.csdn.net/AIXT2006/archive/2009/05/31/4229779.aspx
此问题已解决。经过LeoJay的指导:
“关于你不能import module的问题,我想是因为你没有把build.arm/build/lib.linux-i686-2.5目录里的文件复制到arm的/lib/python2.5/lib-dynload目录下的原因吧。像socket, time, datetime,都是动态链接库,要放到这个目录下的。”
我发现不能import的module确实都与/lib/python2.5/lib-dynload文件夹里的动态链接库有关,呵呵,小惭愧一下,其实我是个python新手,没有LeoJay的指点,我想我短期之内是绝对找不到这个原因的。
我发现我的ARM平台里/lib/python2.5/lib-dynload目录下动态链接库文件都有了,与build/lib.linux-i686-2.5目录里的文件一致,于是我想到了将lib-dynload目录也导出到环境变量:
export PYTHONHOME=/lib/python2.5
export PYTHONPATH=.:$PYTHONHOME:$PYTHONHOME/site-packages:$PYTHONHOME/lib-dynload
export PATH=$PATH:$PYTHONHOME:$PYTHONPATH
此时,datetime、time、socket、pdb等这些module就都可以import了,好不Highpy!
此时对于import sqlite3,还是会报错:
ImportError: libsqlite3.so.0: cannot open shared object file
发现sqlite3其实还没有安装到ARM-linux文件系统,于是将sqlite3安装到文件系统中:
# cd /tftpboot/sqlite/_install_gcc3
# cp –a bin/* /tftpboot/nfs_rootfs/bin/
# cp –a lib/* /tftpboot/nfs_rootfs/lib/
(关键是动态链接文件:libsqlite3.so.0)
# sqlite3
SQLite version 3.6.14
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite>
此时运行sqlite3测试程序,即正常连接数据库、插入数据:
/ # python /home/web/cgi-bin/test_sqlite3.py
1: -1
2: [(0, 0, u'tian!')]
3: [(1, 0, u'hello')]
4: [(0, 0, u'tian!')]
5: (1,)
至此,python2.5.4和sqlite 3.6.14就成功移植到arm-linux下,可以在arm-linux平台下,通过python脚本很方便的操作sqlite数据库。
这里采用的是AT91SAM9261 & arm-linux-2.6.20, 此平台较稳定,且内核和文件系统都与arm-linux-gcc 3.4.4相一致,所以后来主要使用些arm-linux平台;在S3C2410A & arm-linux-2.4.18平台未作测试,因为这个平台的网络芯片不太稳定,使用不便。
在ARM板上用boa搭建了一个WEB服务器,并用python编写CGI脚本,写一段测试程序如下:
#!/bin/python
print """Content-type: text/html
<html xmlns = "http://www.w3.org/1999/xhtml">
<head><title>Hello, arm-linux-web-python!</title></head>
<body>"""
print "<p>Hello, arm-linux-web-python!</p>"
print "</body></html>"
通过WEB访问这个CGI,可以正常执行:Hello, arm-linux-web-python!
如果在代码中加入一个import,如:
#!/bin/python
import os
print """Content-type: text/html
<html xmlns = "http://www.w3.org/1999/xhtml">
<head><title>Hello, arm-linux-web-python!</title></head>
<body>"""
print "<p>Hello, arm-linux-web-python!</p>"
print "</body></html>"
此时通过WEB执行CGI,会无法执行,浏览器报错如下:
502 Bad Gateway
The CGI was not CGI/1.1 compliant.
我还希望能通过WEB界面访问arm-linux下的boa服务器,通过cgi-bin下的python写的cgi来操作sqlite数据,完成一个小型嵌入式数据库的插入、修改、删除等,但问题和上面这个“Hello, arm-linux-web-python!”CGI程序的问题一样:
测试CGI源码如下:
#! /bin/python
import sqlite3
def runTest():
cx = sqlite3.connect("test_sqlite3.db")
cu = cx.cursor()
#create
cu.execute('''create table catalog(
id integer primary key,
pid integer,
name varchar(10) unique
)''')
#insert
cu.execute('insert into catalog values(0,0,"tian!")')
cu.execute('insert into catalog values(1,0,"hello")')
cx.commit()
#select
cu.execute('select * from catalog')
print '1:',
print cu.rowcount
rs = cu.fetchmany(1)
print '2:',
print rs
rs = cu.fetchall()
print '3:',
print rs
#delete
cu.execute('delete from catalog where id = 1 ')
cx.commit()
cu.execute('select * from catalog')
rs = cu.fetchall()
print '4:',
print rs
#select count
cu.execute("select count(*) from catalog")
rs = cu.fetchone()
print '5:',
print rs
cu.execute("select * from catalog")
cu.execute('drop table catalog')
cx.close()
if __name__ == '__main__':
runTest()
此程序在arm-linux平台下通过控制台是可以成功运行的,但是通过boa服务器访问,这不能成功运行,浏览器报错如下:
502 Bad Gateway
The CGI was not CGI/1.1 compliant.
这个问题我觉得还是跟boa有关,即在boa中运行的python CGI不能有import语句,是不是boa的某个设置呢?希望某位大牛能指点一二,小弟感激不尽!