编程语言
首页 > 编程语言> > php-PRESTASHOP:如何告诉PDO类通过套接字而不是’localhost’连接?

php-PRESTASHOP:如何告诉PDO类通过套接字而不是’localhost’连接?

作者:互联网

在函数_getPDO的/classes/db/DbPDO.php中的Prestashop 1.6.1中,我看到dsn连接字符串的PDO是有条件构建的.特别值得关注的是以下代码片段:

$dsn = 'mysql:';
if ($dbname)
        $dsn .= 'dbname='.$dbname.';';
if (preg_match('/^(.*):([0-9]+)$/', $host, $matches))
        $dsn .= 'host='.$matches[1].';port='.$matches[2];
elseif (preg_match('#^.*:(/.*)$#', $host, $matches))
        $dsn .= 'unix_socket='.$matches[1];
else
        $dsn .= 'host='.$host;

因此,为了将连接类型设置为unix_socket,期望在$host中看到什么?

我想它正在看settings.inc.php中的_DB_SERVER_变量.那正确吗?
目前,我将其设置为“ localhost”.我需要将其更改为使用套接字/var/lib/mysql/mysql.sock连接PDO吗?

感谢您的任何建议,
雷恩

解决方法:

查看代码,这似乎是窍门:

define('_DB_SERVER_', 'unix:/var/lib/mysql/mysql.sock');

冒号之前无关紧要的事情.重要的是字符串始于一行的开头,先有一个冒号然后是斜杠(“:/”),此后的所有内容都是套接字文件的绝对路径.因此,此模式需要套接字的绝对路径.

_DB_SERVER_常量似乎是根据文档配置PrestaShop数据库的规范方法.

标签:prestashop,mysql,php,pdo
来源: https://codeday.me/bug/20191119/2040045.html