无法通过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数据库的主要内容,如果未能解决你的问题,请参考以下文章

无法使用 Hibernate 连接到 Informix

无法将 Spring Boot 应用程序连接到 IBM Informix 数据库

通过 Python 连接到 UCCX 数据库 (Informix)

从 Windows 通过 Entity Framework 连接到 Informix 的问题

如何从 ASP.NET 脚本连接到 Informix 数据库?

在 Windows 上使用 pyodbc 连接到 Informix