Python2.5.4移植项目:import module问题的解决与boa服务器CGI访问问题

 

承接上一篇文章:《Python2.5.4移植到arm-linux

http://blog.csdn.net/AIXT2006/archive/2009/05/31/4229779.aspx

 

1       Import module问题的解决

此问题已解决。经过LeoJay的指导:

“关于你不能import module的问题,我想是因为你没有把build.arm/build/lib.linux-i686-2.5目录里的文件复制到arm/lib/python2.5/lib-dynload目录下的原因吧。像socket, time, datetime,都是动态链接库,要放到这个目录下的。”

我发现不能importmodule确实都与/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

此时,datetimetimesocketpdb等这些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.4sqlite 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平台未作测试,因为这个平台的网络芯片不太稳定,使用不便。

 

2       Boa服务器运行python CGI无法import

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的某个设置呢?希望某位大牛能指点一二,小弟感激不尽!

 

你可能感兴趣的:(sqlite,python,服务器,Module,cgi,import)