无法通过php连接到informix数据库
Posted
技术标签:
【中文标题】无法通过php连接到informix数据库【英文标题】:Unable to connect to informix database through php 【发布时间】:2014-07-08 17:20:50 【问题描述】:这是我到目前为止所做的............
为了将我的网站连接到informix数据库,我安装了Informix客户端SDK并通过Setnet32输入服务器和主机信息,通过ConnectTest Demo测试连接正常。
然后通过 Windows 中的 ODBC 数据源管理器,我创建了用户 DSN 和系统 DSN 并测试了连接。
现在我创建了一个连接字符串,如下所示:
$dbh = new PDO("odbc:Driver=IBM INFORMIX ODBC DRIVER;HOSTNAME=172.56.100.12;PORT=8056;DATABASE=eadmin;PROTOCOL=onsoctcp; UID=prsnl;PWD=prsnl;");
在这种情况下尝试登录时,我得到的错误如下:
PDOException: SQLSTATE[HY000] SQLDriverConnect: -11060 [Informix][Informix ODBC Driver]General error.
我尝试了另一个这样的连接字符串:
$dbh = new PDO("Dsn=bnm_info;Driver=IBM INFORMIX ODBC DRIVER;HOSTNAME=172.56.100.12;PORT=8056;DATABASE=eadmin;PROTOCOL=onsoctcp; UID=prsnl;PWD=prsnl;");
在这种情况下,我得到的错误如下:
PDOException: invalid data source name
为了更清楚,访问数据库的代码如下:
$query = "select decrypt_char(passwd,'" . $_POST['passwd'] . "') from edak_users where userid='" . $_SESSION['username'] . "'";
$tt = $dbh->query($query);
$rs=$tt->fetch(PDO::FETCH_NUM);
请提出一个解决方案让我度过难关,因为这个问题让我发疯了。
非常欢迎任何帮助。 期待中的感谢
【问题讨论】:
就问题而言,查询是无关紧要的——你甚至没有连接到数据库,所以查询永远不会有机会被执行。这是一件好事,因为你很容易受到SQL injection attacks 请建议如何通过odbc连接数据库 【参考方案1】:使用 odbc.ini 的示例 #1 PDO_INFORMIX DSN 示例
以下示例显示了一个 PDO_INFORMIX DSN
用于连接到在 odbc.ini
中编目为 Infdrv33 的 Informix 数据库:
PHP
$db = new PDO("informix:DSN=Infdrv33", "", "");
[ODBC Data Sources]
Infdrv33=INFORMIX 3.3 32-BIT
Odbc.ini
[Infdrv33]
Driver=/opt/informix/csdk_2.81.UC1G2/lib/cli/iclis09b.so
Description=INFORMIX 3.3 32-BIT
Database=common_db
LogonID=testuser
pwd=testpass
Servername=ids_server
DB_LOCALE=en_US.819
OPTIMIZEAUTOCOMMIT=1
ENABLESCROLLABLECURSORS=1
示例 #2 PDO_INFORMIX DSN 示例使用连接字符串
以下示例显示了一个 PDO_INFORMIX DSN
,用于使用 Informix 连接字符串语法连接到名为 common_db
的 Informix 数据库。
$db = new PDO("informix:host=host.domain.com; service=9800;
database=common_db; server=ids_server; protocol=onsoctcp;
EnableScrollableCursors=1", "testuser", "tespass");
source
【讨论】:
您的意思是我需要将示例 1 中的语句添加到 odbc.ini 文件中? ?【参考方案2】:你有没有尝试过更简单的连接字符串:
$dbh = new PDO("DSN=bnm_info;UID=prsnl;PWD=prsnl;");
如果您在 Win64 上工作,请确保您在正确的 odbcad32.exe
中定义了 DSN。有一个用于 32 位应用程序,另一个用于 64 位应用程序。
如果您的 ODBC 从 odbcad32.exe
工作,那么它应该可以使用这样简单的连接字符串。
【讨论】:
【参考方案3】:如果您尝试在 Windows 上运行它,请忘记 odbc.ini,在 Windows 上,该信息存储在注册表中。
初始 -11060 General Error 的原因是因为您在连接字符串 (SERVER) 中缺少关键参数
没有它(像您一样使用无 DSN 连接)
D:\Infx\php7\test>cat p2.php
<?php
$dbh = new PDO("odbc:Driver=IBM INFORMIX ODBC DRIVER;HOSTNAME=420ito;PORT=9088;DATABASE=sysmaster;PROTOCOL=onsoctcp;UID=informix;PWD=ximrofni;");
try
$query = "select tabname from systables where tabid=99";
$tt = $dbh->query($query);
$rs=$tt->fetch(PDO::FETCH_NUM);
print_r($rs);
catch (Exception $e)
echo "*".$e->getMessage()."*";
?>
D:\Infx\PHP7\test>php p2.php
PHP Fatal error: Uncaught PDOException: SQLSTATE[HY000] SQLDriverConnect: -11060 [Informix][Informix ODBC Driver]General error. in D:\Infx\PHP7\test\p2.php:2
Stack trace:
#0 D:\Infx\PHP7\test\p2.php(2): PDO->__construct('odbc:Driver=IB...')
#1 main
thrown in D:\Infx\PHP7\test\p2.php on line 2
D:\Infx\PHP7\test>grep SERVER p2.php
现在,它与服务器连接没有错误:
D:\Infx\PHP7\test>grep SERVER p2.php
$dbh = new PDO("odbc:Driver=IBM INFORMIX ODBC DRIVER;SERVER=ids1210;HOSTNAME=420ito;PORT=9088;DATABASE=sysmaster;PROTOCOL=onsoctcp;UID=informix;PWD=ximrofni;");
D:\Infx\PHP7\test>php p2.php
Array
(
[0] => VERSION
)
D:\Infx\PHP7\test>
SERVER 应该是您的 Informix 服务器的名称(通常是 INFORMIXSERVER 环境变量的值)。
如果您已经将 Informix 服务器信息放入注册表(使用 setnet32),则无需指定 ODBC 连接字符串中的所有参数。 你可以这样做:
$dbh = new PDO("odbc:Driver=IBM INFORMIX ODBC DRIVER;SERVER=ids1210;DATABASE=sysmaster;UID=informix;PWD=ximrofni;");
驱动程序将从注册表中选择其余的值。
此外,如前所述,如果您已经创建了 ODBC DSN,则可以仅引用该 DSN。像这样:
$dbh = new PDO("odbc:DSN=ids1210_32;UID=informix;PWD=ximrofni;");
请记住,如果您的 PHP(模块)是 64 位,您将需要创建一个 64 位 ODBC DSN 或使用“IBM INFORMIX ODBC DRIVER (64-bit)”作为驱动程序名称您的无 dsn 连接字符串。
如果您不想在注册表中存储任何内容,则“无 DSN”选项(包括驱动程序名称在内的所有参数)非常有用,但使用哪一个完全取决于您;)
【讨论】:
以上是关于无法通过php连接到informix数据库的主要内容,如果未能解决你的问题,请参考以下文章
无法将 Spring Boot 应用程序连接到 IBM Informix 数据库
通过 Python 连接到 UCCX 数据库 (Informix)
从 Windows 通过 Entity Framework 连接到 Informix 的问题