【发布时间】:2021-06-26 17:36:48
【问题描述】:
我有一个 config.php 文件如下:
//file name: config.php -------------
define ("DOMAIN","mydomain.com");
//connection parameters
$host = '127.0.0.1';
$db = 'test';
$user = 'root';
$pass = '';
$charset = 'utf8mb4';
$dsn = "mysql:host=$host;dbname=$db;charset=$charset";
$options = [
PDO::ATTR_ERRMODE => PDO::ERRMODE_SILENT,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
PDO::ATTR_EMULATE_PREPARES => false,
];
try {
$pdo = new PDO($dsn, $user, $pass, $options);
echo "Database connected successfully!";
} catch (PDOException $e) {
throw new PDOException($e->getMessage());
}
现在我在 index.php 中包含了这个文件,如下所示:
//file name: index.php -----------
require_once("../path to/config.php");
echo "WELCOME to <h1 style='display:inline;color:#000080;'>".DOMAIN."</h1>";
如您所见,凭据是假的,它将无法连接到数据库,因此错误消息显示如下:
Fatal error: Uncaught PDOException: SQLSTATE[28000] [1045] Access denied for user 'root'@'localhost' (using password: NO) in /home/hosting_account/path to/config.php:20 Stack trace: #0 /home/hosting_account/public_html/index.php(22): require_once() #1 {main} thrown in /home/hosting_account/path to/config.php on line 20
我在这里删除了实际路径,但提到了路径的布局。一切正常。。错误信息也正常。
但是我想要的是,index.php 的第一行将执行/显示(欢迎来到 mydomain.com),即使包含文件的一部分(这里是连接部分)会有错误。由于定义 DOMAIN 并从 index.php 回显它没有错误,我希望它会显示“欢迎来到 mydomain.com”,然后会显示从 pdo 连接捕获的错误消息。
怎么做?
【问题讨论】:
-
如果您将
throw new PDOException($e->getMessage());替换为其他名称,例如$pdo_error = 1; $message = $pdo->getMessage(),则可以在欢迎信息后抛出它
标签: php pdo error-handling