繁体   English   中英

PHP MySQLi与SSL的持久连接

[英]PHP MySQLi persistent connections with SSL

我在通过ssl配置持久的MySQLi连接时遇到问题。 任何建议表示赞赏。

无持久连接:

$flags = MYSQLI_CLIENT_SSL;
$link = new mysqli();
$link->ssl_set(null, null, null, null, "RC4-MD5");
if ($link->real_connect($host, $user, $pass, $db, $port, null, $flags)) {
    $r = $link->query("SHOW STATUS LIKE 'Ssl_cipher'");
    var_dump($r->fetch_row());
}

输出是

array(2) {
   [0]=> string(10) "Ssl_cipher"
   [1]=> string(18) "RC4-MD5"
}

与持久连接:

$flags = MYSQLI_CLIENT_SSL;
$link = new mysqli();
$link->ssl_set(null, null, null, null, "RC4-MD5");
if ($link->real_connect('p:' . $host, $user, $pass, $db, $port, null, $flags)) {
    $r = $link->query("SHOW STATUS LIKE 'Ssl_cipher'");
    var_dump($r->fetch_row());
}

输出是

array(2) {
   [0]=> string(10) "Ssl_cipher"
   [1]=> string(0) ""
}

更新:我相信这是一个PHP错误https://bugs.php.net/bug.php?id=55283-对于永久连接,基本上ssl_set()被忽略了,在我的情况下,由于服务器配置,该连接降级为非SSL。

您必须在real_connect之前先运行mysqli :: ssl_set。

http://www.php.net/manual/zh/mysqli.ssl-set.php

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM