对于我们自己服务器上的项目,我已经多次使用 PHP 访问 MySQL 数据库,并且总是使用相同的 PHP 脚本来访问(显然更改了登录详细信息)。然而,这是我第一次使用 Heroku 和 ClearDB,我遇到了问题。
该数据库位于我们使用 ClearDB 的 Heroku PHP 应用程序上,我访问了 CLEARDB_DATABASE_URL 以找出用户名、密码、主机名和数据库名称。为了确保我做得正确,我的理解是这是格式:
mysql://USER_NAME:PASSWORD@HOST_NAME/DATABASE_NAME?reconnect=true
在 MySQL Workbench 中使用这些详细信息,我设法登录到数据库并添加了一个表,所以我相信它们是正确的详细信息。
但是,当我尝试使用我的 PHP 脚本访问它时,使用从 URL 获取的相同变量,我收到以下错误:
HTTP Error 500 (Internal Server Error): An unexpected condition was encountered while the server was attempting to fulfill the request.
起初我认为 Heroku 应用程序可能已经完成,但我仍然可以访问 PHP 脚本中不尝试访问数据库的任何函数。
正如我所说,这个脚本以前一直有效,所以我不确定问题出在哪里。我的数据库连接位于具有以下构造函数的单独类中:
function __construct()
{
$this->DB_HOST = 'us-cdbr-east-02.cleardb.com';
$this->DB_USERNAME = 'the_username_from_url';
$this->DB_PASSWORD = 'the_password_from_url';
$this->DB_DATABASE = 'the_database_name_from_url';
}
使用其他类根据需要调用的 connect() 函数:
function connect()
{
self::$instance = new mysqli($this->DB_HOST, $this->DB_USERNAME, $this->DB_PASSWORD, $this->DB_DATABASE);
if (mysqli_connect_errno()) {
$this->raise_error(printf("Connect failed: %s\n", mysqli_connect_error()));
}
return self::$instance;
}
我 99.9% 确定问题是由尝试连接到数据库引起的。尽管当我在浏览器中测试脚本时它没有返回任何 PHP 错误消息,但只有基于 DB 的函数会导致 500 错误。
我愿意接受任何和所有的建议......