duancanjiu3754 2014-04-30 02:24
浏览 37
已采纳

使用php pdo无法验证MySQL数据库

well the title says enough I guess! my db connection always fails for the verification for some reason...

<?php
//main.php\\
require('database_pdo.php');
$con = new Database($dbhost,$dbusername,$dbpassword,$dbname);
if($con){
    header("Refresh: 5; url=index.php");
    $message = '<font color="LIME"><center>The page will refresh within 5 seconds to     the next step!<br /><img src="./theme/main/CountDown.gif"/></center></font>';
}else{
    $message = '<font color="RED"><center>Database connection failed!<br />Please try again and/or check your connection info!<br />Error Given:<br />'.$dberror.'</center></font>';
}

//database_pdo.php\\
class Database extends PDO
    {
            private $db;
            public function Database($host, $user, $pass, $db) {
                    try {
                            $this->db = new PDO("mysql:dbname=".$db.";host=".$host.";", $user, $pass);             
                    } catch(PDOEXCEPTION $e) {
                            $dberror = 'An error has occurred! [Code: '.$e->getCode().']!<br/>More info: ['.$e->getMessage().']!';
                    }
            }
            public function runQuery($query) {
                    try{
                            return $this->db->query($query);
                    } catch(PDOEXCEPTION $e) {
                            $dberror = 'An error has occurred! [Code: '.$e->getCode().']!<br/>More info: ['.$e->getMessage().']!';
                    }              
            }
    }
?>

can anybody help me it would be apperciated! it's a really annoying error so it must be fixd as soon as possible I asked it in the chat but neither one knew so this might help me better

  • 写回答

1条回答 默认 最新

  • dopt85756 2014-04-30 02:25
    关注

    Try this

    <?php
    //main.php\\
    global $dberror;
    $dberror = "";
    require('database_pdo.php');
    $con = new Database($dbhost,$dbusername,$dbpassword,$dbname);
    if($con->db){
        header("Refresh: 5; url=index.php");
        $message = '<font color="LIME"><center>The page will refresh within 5 seconds to the next step!<br /><img src="./theme/main/CountDown.gif"/></center></font>';
    }else{
        $message = '<font color="RED"><center>Database connection failed!<br />Please try again and/or check your connection info!<br />Error Given:<br />'.$dberror.'</center></font>';
    }
    
    //database_pdo.php\\
    class Database
        {
            var $db;
            public function __construct($host, $user, $pass, $db) {
                 global $dberror;
                try {
                    $this->db = new PDO("mysql:dbname=".$db.";host=".$host.";", $user, $pass);        
                } catch(PDOEXCEPTION $e) {
                    $dberror = 'An error has occurred! [Code: '.$e->getCode().']!<br/>More info: ['.$e->getMessage().']!';
                }
            }
            public function runQuery($query) {
                global $dberror;
                try{
                    return $this->db->query($query);
                } catch(PDOEXCEPTION $e) {
                    $dberror = 'An error has occurred! [Code: '.$e->getCode().']!<br/>More info: ['.$e->getMessage().']!';
                }        
            }
        }
    ?>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作