5.2.xからphp5.3.xに移行したサーバーのアップグレードがありました。私はmysqlpdoで、アップグレード前に機能していた以下のコードを示しています。
<?php
error_reporting(E_ALL);
ini_set('display_errors', '1');
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Database user / pass
*/
$sql_details = array(
"user" => "",
"pass" => "",
"host" => "",
"db" => ""
);
// This is included for the development and deploy environment used on the DataTables
// server. You can delete this block - it just includes my own user/pass without making
// them public!
if ( is_file($_SERVER['DOCUMENT_ROOT']."/datatables/pdo.php") ) {
include( $_SERVER['DOCUMENT_ROOT']."/datatables/pdo.php" );
}
// /End development include
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Database connection
*/
/* PDO connection */
$db = new PDO(
"mysql:host={$sql_details['host']};dbname={$sql_details['db']}",
$sql_details['user'],
$sql_details['pass'],
array(
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
)
);
/* mysql_* connection */
/*
if ( ! $db = mysql_pconnect( $sql_details['host'], $sql_details['user'], $sql_details['pass'] ) ) {
header( $_SERVER['SERVER_PROTOCOL'] .' 500 Internal Server Error' );
die( 'Could not open connection to server' );
}
if ( ! mysql_select_db( $sql_details['db'], $db ) ) {
header( $_SERVER['SERVER_PROTOCOL'] .' 500 Internal Server Error' );
die( 'Could not select database' );
}
*/
しかし、アップグレード後、PDOクラスが見つからないという致命的なエラーが発生します。ht php.iniを確認すると、pdoが有効になっています。以下はphp.iniのスニペットです。
'--with-mysql=/usr' '--with-mysql-sock=/var/lib/mysql/mysql.sock' '--with-mysqli=/usr/bin/mysql_config' '--with-openssl=/usr' '--with-openssl-dir=/usr' '--with-pcre-regex=/opt/pcre' '--with-pdo-mysql=shared' '--with-pdo-sqlite=shared' '--with-pic' '--with-png-dir=/usr' '--with-sqlite=shared' '--with-xpm-dir=/usr' '--with-zlib' '--with-zlib-dir=/usr'
pdo_mysql
pdo_mysql.default_socket => /var/lib/mysql/mysql.sock => /var/lib/mysql/mysql.sock
pdo_sqlite
ここで何が問題なのか教えていただけませんか?
よろしくお願いします、Srini。