这篇文章展示了如何在 Windows 上安装 XAMPP 以运行连接到远程 Oracle 数据库的 PHP 应用程序。
*
XAMPP 是一个开源包,包含 Apache、PHP 和许多 PHP
'扩展'。其中一个扩展是 PHP OCI8,它连接到
甲骨文数据库。
*
要安装 XAMPP:D:驱动器。
下载“XAMPP for Windows”并按照安装向导进行操作。我安装到我的 D: 驱动器中。
通过 XAMPP 控制面板启动 Apache 服务器。
通过浏览器访问http://localhost/dashboard/phpinfo.php,查看已安装 PHP 的架构和线程安全模式。请注意,这是已安装 PHP 的架构,而不是您机器的架构。可以在 x64 机器上运行 x86 PHP。
Oracle OCI8 预装在 XAMPP 中,但如果您需要更新版本,可以从 pecl.php.net 下载更新的 OCI8 PECL 包。
选择一个OCI8版本,根据架构和线程安全模式选择DLL。例如,如果 PHP 是 x86 并且启用了线程安全,请下载“7.2 Thread Safe (TS) x86”。然后将“D:\xampp\php\ext\php_oci8_12c.dll”替换为 OCI8 PECL 包中的新“php_oci8_12c.dll”。
编辑“D:\xampp\php\php.ini”并取消注释“extension=oci8_12c”行。确保“extension_dir”设置为包含 PHP 扩展 DLL 的目录。例如,
extension=oci8_12c
extension_dir="D:\xampp\php\ext"
从OTN. 下载 Oracle Instant Client Basic 软件包
选择正确的架构以与 PHP 保持一致。对于 Windows x86,请从 Windows 32 位页面下载“instantclient-basic-nt-12.2.0.1.0.zip”。
将文件解压到“D:\Oracle”等目录中。将创建一个子目录“D:\Oracle\instantclient_12_2”。
将此子目录添加到 PATH 环境变量中。您可以在控制面板 -> 系统 -> 高级系统设置 -> 高级 -> 环境变量 -> 系统变量 -> PATH 中更新 PATH。在我的示例中,我将其设置为“D:\Oracle\instantclient_12_2”。
重新启动 Apache 服务器并再次检查 phpinfo.php 页面。说明OCI8扩展加载成功。
如果您还从终端窗口运行 PHP,请确保关闭并重新打开终端以获取更新后的 PATH 值。
要运行您的第一个 OCI8 应用程序,请在 XAMPP 文档根目录“D:\xampp\htdocs\test.php”中创建一个新文件。它应该包含:
<?php
error_reporting(E_ALL);
ini_set('display_errors', 'On');
$username = "hr"; // Use your username
$password = "welcome"; // and your password
$database = "localhost/orclpdb"; // and the connect string to connect to your database
$query = "select * from dual";
$c = oci_connect($username, $password, $database);
if (!$c) {
$m = oci_error();
trigger_error('Could not connect to database: '. $m['message'], E_USER_ERROR);
}
$s = oci_parse($c, $query);
if (!$s) {
$m = oci_error($c);
trigger_error('Could not parse statement: '. $m['message'], E_USER_ERROR);
}
$r = oci_execute($s);
if (!$r) {
$m = oci_error($s);
trigger_error('Could not execute statement: '. $m['message'], E_USER_ERROR);
}
echo "<table border='1'>\n";
$ncols = oci_num_fields($s);
echo "<tr>\n";
for ($i = 1; $i <= $ncols; ++$i) {
$colname = oci_field_name($s, $i);
echo " <th><b>".htmlspecialchars($colname,ENT_QUOTES|ENT_SUBSTITUTE)."</b></th>\n";
}
echo "</tr>\n";
while (($row = oci_fetch_array($s, OCI_ASSOC+OCI_RETURN_NULLS)) != false) {
echo "<tr>\n";
foreach ($row as $item) {
echo "<td>";
echo $item!==null?htmlspecialchars($item, ENT_QUOTES|ENT_SUBSTITUTE):" ";
echo "</td>\n";
}
echo "</tr>\n";
}
echo "</table>\n";
?>
您需要编辑此文件并设置您的数据库用户名、密码和连接字符串。如果您使用的是 Oracle 数据库 XE,则连接字符串应为“localhost/XE”。
也可以更改 SQL 查询。目前它查询每个用户都有的特殊 DUAL 表。
使用http://localhost/test.php 在浏览器中加载测试程序。输出将是名为“DUMMY”的列中的单个值“X”。
---- 注意
也许这会有所帮助,但这个问题在 XAMPP 中非常复杂。我在 xampp 中听到过一些关于这个问题的报告,我建议免费测试 VPS 以进一步研究。
如果您有任何问题,请在 cmets 中发帖。
如果有不兼容或错误的地方,请务必发表评论!谢谢