php 调用com组件读取 mdb,access文件数据

使用注意事项

PHP 5.4.5以前的版本,只需要在php.ini中把com.allow_dcom = true打开就可以了,

但是5.4.5版本以后,PHP把com/dotnet 模块集成到了一个单独的扩展中,

所以需要在php.ini中加一行扩展extension=php_com_dotnet.dll,是加一行,不是打开,默认配置文件中没有这一行的,然后重启IIS或Apache,再次运行就正常了!

com组件时windows 独有的不能在linux上执行

1.检查php目录ext文件夹下面php_com_dotnet.dll是否存在

2.在php.ini里面加入以下语句:

[PHP_COM_DOTNET]
extension=php_com_dotnet.dll

3.php.ini中设置

​ 去掉前面的分号

com.allow_dcom = true

具体代码实现

<?php
//创建一个Connection对象 
$conn = new COM("ADODB.Connection") or die("创建COM失败");

//链接mdb 文件
$connstr = "DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=". realpath("./db.mdb");
$conn->Open($connstr);

//创建一个Recordcount对象 
$rs = new COM("ADODB.RecordSet") or die("创建RS失败");
/**
 * 参数1 : sql 字符串
 * 参数2 :连接对象
 * 参数3 : 打开方式
 *       0 只读,   数据只能向下移动
 *       1 可读写,数据可以自由移动,多用户下别人不能看到新增数据(除非重启动)
 *       2 可读写,数据可以自由移动,多用户下别人可以看到新增数据
 *       3 只读 , 数据可以自由移动  
 * 参数4 : 锁定类型
 *       1 默认值,   只读
 *       2 悲观锁定
 *       3 乐观锁定
 *       4 批次乐观锁定
 */
$rs->Open("select * from SmartCard",$conn,1,1);
while(!$rs->eof) {
    //取字段名和值
        //方式1
    echo $rs->Fields("ID")->name;
    echo " : ";
    echo $rs->Fields("ID")->value;
    echo "-----";
    
    //方式2
    echo $rs->Fields(0)->name;
    echo " : ";
    echo $rs->Fields(0)->value;
    echo "-----";
    
    //换行
    echo "<br>";
    $rs->MoveNext();
}
// 释放资源
$rs->Close();
$conn->Close();
$rs = null;
$conn = null;
?>

如果结合文件上传mdb文件,再读取mdb文件,需要注意的地方

上传文件大小的设置

打开php.ini,首先找到

     file_uploads = on ;是否允许通过HTTP上传文件的开关。默认为ON即是开
        upload_tmp_dir ;文件上传至服务器上存储临时文件的地方,如果没指定就会用系统默认的临时文件夹
        upload_max_filesize = 8m ;望文生意,即允许上传文件大小的最大值。默认为2M
        post_max_size = 8m ;指通过表单POST给PHP的所能接收的最大值,包括表单里的所有值。默认为8M

一般地,设置好上述四个参数后,上传<=8M的文件是不成问题,在网络正常的情况下。

但如果要上传>8M的大体积文件,只设置上述四项还一定能行的通。

进一步配置以下的参数

     max_execution_time = 600 ;每个PHP页面运行的最大时间值(秒),默认30秒
        max_input_time = 600 ;每个PHP页面接收数据所需的最大时间,默认60秒
        memory_limit = 8m ;每个PHP页面所吃掉的最大内存,默认8M

把上述参数修改后,在网络所允许的正常情况下,就可以上传大体积文件了

     max_execution_time = 600
        max_input_time = 600
        memory_limit = 32m
        file_uploads = on
        upload_tmp_dir = /tmp
        upload_max_filesize = 32m
        post_max_size = 32m