错误的PDO SSL连接

问题描述:

我正在试图从我的Windows机器连接到我的Linux系统中,当出现以下错误:错误的PDO SSL连接

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'; 

任何想法表示欢迎。

+0

在您的Linux机器上配置了Open SSL吗? – 2014-10-03 15:58:56

+0

我相信,但有没有办法测试它? – Ukuser32 2014-10-03 16:06:31

+0

运行'openssl version'命令。 – 2014-10-03 16:09:48

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