PDO SSL连接出错

时间:2014-10-03 15:49:02

标签: php mysql pdo openssl

尝试从Windows框连接到Linux框时出现以下错误:

Warning: PDO::__construct(): SSL operation failed with code 1. OpenSSL Error messages: error:1408F10B:SSL routines:SSL3_GET_RECORD:wrong version number

这是连接代码:

    $dbE = new PDO(
                    'mysql:dbname=db_name;host=host_ip;',
                    'username',
                    'password',
                    array(                                                                                     
                            PDO::MYSQL_ATTR_SSL_KEY         =>'client_side_path\client-key.pem',
                            PDO::MYSQL_ATTR_SSL_CERT        =>'client_side_path\client-cert.pem',
                            PDO::MYSQL_ATTR_SSL_CA          =>'client_side_path\ca-cert.pem'
                    )                                  
                   );
    $dbE->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

    echo 'Connected';  

欢迎任何想法。

1 个答案:

答案 0 :(得分:2)

修正了它。原因是因为服务器B中到CA的路径不正确。值得注意的是,为了解决这个问题,我直接从服务器A尝试了PHP之外的连接,它出现了一个错误"其他签名确认错误" - 然后我加载了CA证书,发现它是空的。重新启动服务器,在my.cnf 服务器启动调用中设置正确的路径并且全部修复。真的值得尝试mysql直接连接,因为它给出了一个非常不同的错误,它比PDO更有用。