PHP: 使用 PDO 將 PHP 連接到 MySQL
本文件是連接到 MySQL指南的一部分。請在此處查看完整指南:學習如何使用 MySQLi 和 PDO 從 PHP 連接到 MySQL。
👋 歡迎來到 Stackhero 文檔!
Stackhero 提供一個即用型的 PHP cloud 解決方案,帶來多項優勢,包括:
- 只需一個簡單的
git push,即可在幾秒鐘內部署您的應用程式。- 使用您自己的域名,並享受 HTTPS 證書的自動配置,以增強安全性。
- 享受自動備份、一鍵更新,以及簡單、透明且可預測的定價,讓您高枕無憂。
- 通過專用的私人 VM獲得最佳的性能和強大的安全性。
節省時間並簡化您的生活:只需 5 分鐘即可嘗試 Stackhero 的 PHP cloud hosting 解決方案!
PDO 提供了一種靈活的方法來將 PHP 連接到 MySQL。下面的示例說明如何使用 PDO 建立連接。它還解決了如果您的系統無法訪問 CA 證書可能出現的 SSL 證書問題。
<?php
$hostname = '<XXXXXX>.stackhero-network.com';
$user = 'root';
$password = '<yourPassword>';
$database = 'root'; // 對於生產環境,考慮創建專用的數據庫和用戶
$dsn = "mysql:host=$hostname;dbname=$database";
$options = array(
// 如果您遇到類似 "Uncaught PDOException: PDO::__construct(): SSL operation failed with code 1..." 的錯誤,
// 可能是因為 /etc/ssl/certs/ 目錄缺少 CA 證書
PDO::MYSQL_ATTR_SSL_CAPATH => '/etc/ssl/certs/',
// PDO::MYSQL_ATTR_SSL_CA => 'isrgrootx1.pem',
PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT => true,
);
$pdo = new PDO($dsn, $user, $password, $options);
$stm = $pdo->query('SELECT VERSION()');
$version = $stm->fetch();
echo '您已連接到運行版本 ' . $version[0] . " 的數據庫\n";
?>
處理 "SSL operation failed with code 1" 錯誤
如果您看到類似 Uncaught PDOException: PDO::__construct(): SSL operation failed with code 1. OpenSSL Error messages: error:0A000086:SSL routines::certificate verify failed 的錯誤,可能是因為您的系統的 /etc/ssl/certs/ 目錄中沒有必要的 CA 證書。
如果您可以訪問運行 PHP 代碼的系統,您可以按以下方式安裝證書:
- 在 Ubuntu/Debian 上,運行
sudo apt-get install ca-certificates - 在 Alpine Linux 上,運行
apk add ca-certificates
如果您無法直接在系統上安裝這些證書,您可以手動安裝證書:
- 將證書下載到您的電腦:https://letsencrypt.org/certs/isrgrootx1.pem
- 將
isrgrootx1.pem文件添加到您的 PHP 項目文件中。 - 註釋掉
PDO::MYSQL_ATTR_SSL_CAPATH => '/etc/ssl/certs/'行 - 取消註釋
PDO::MYSQL_ATTR_SSL_CA => 'isrgrootx1.pem'行