尝试从我的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';
欢迎任何想法.
解决方法:
固定它.原因是因为服务器B中到CA的路径不正确.值得注意的是,为了解决这个问题我直接从服务器A尝试了PHP之外的连接,并且它出现了错误“其他签名确认错误” – 然后我加载了CA证书并发现它是空的.重新启动服务器,在my.cnf和服务器启动调用中设置正确的路径并且全部修复.真的值得尝试mysql直接连接,因为它给出了一个非常不同的错误,这比PDO更有用.
标签:php,mysql,pdo,openssl 来源: https://codeday.me/bug/20190703/1362982.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。