我尝试像这样连接到远程主机:
class Singleton {
public static $connection;
public static function getConnection(){
if(self::$connection==null){
$dsn = 'mysql:dbname=gtrscrpt_ubot;';
$user = 'MyUser';
$password = 'MyPassword';
try {
self::$connection = new PDO('mysql:host=gator188.hostgator.com;port=2983;dbname=gtrscpt_ubot;',$user,$password );
self::$connection->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {
echo 'Connection failed: ' . $e->getMessage();
}
}
return self::$connection;
}
}
Singleton::getConnection();
我明白了:
Connection failed: SQLSTATE[HY000] [2006] MySQL server has gone away
问题是我不知道我的代码是错误还是无法真正连接到服务器(但我知道我应该连接)
更新: 连接失败:SQLSTATE[HY000] [2000] mysqlnd 无法使用旧的不安全身份验证连接到 MySQL 4.1+。请使用管理工具通过命令 SET PASSWORD = PASSWORD('your_existing_password') 重置密码。这将在 mysql.user 中存储一个新的、更安全的哈希值。如果此用户在 PHP 5.2 或更早版本执行的其他脚本中使用,您可能需要从 my.cnf 文件中删除 old-passwords 标志**