douda5227 2018-04-02 22:01
浏览 99

PHP proc_open - 连接到mysqldump工作,但不是mysql

I have the problem, that mysql does not allow me to connect in one case, but in another one it does.

i am using proc_open to connect to mysql via the mysqldump command and pass the password through the pipe.

interestingly this call works as expected, whereas the other one doesn't....

$command = "mysqldump --no-data -h 127.0.0.1 -u root -p dbname > /var/www/html/dump.sql"
$process = proc_open($command, [
    0 => ["pipe", "r"],
    1 => ["pipe", "w"],
    2 => ["pipe", "w"]
], $pipes);

if (is_resource($process))
{
    fwrite($pipes[0], $this->password);
    fclose($pipes[0]);
    ...

the next call does not work - ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES).

i really don't understand that, because the connection establishment should be the same for mysql and mysqldump. i can assure, that the password is correct, because it is fetched from a config file and I already checked by debugging.

if i execute the same command directly on shell, i don't have a problem to connect by entering the password. but through php it does not work.

$command = "mysql -h 127.0.0.1 -u root -p -D dbname < /var/www/html/dump.sql"
$process = proc_open($command, [
    0 => ["pipe", "r"],
    1 => ["pipe", "w"],
    2 => ["pipe", "w"]
], $pipes);

if (is_resource($process))
{
    fwrite($pipes[0], $this->password);
    fclose($pipes[0]);
    ...
  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 使用C#,asp.net读取Excel文件并保存到Oracle数据库
    • ¥15 C# datagridview 单元格显示进度及值
    • ¥15 thinkphp6配合social login单点登录问题
    • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
    • ¥15 如何在scanpy上做差异基因和通路富集?
    • ¥20 关于#硬件工程#的问题,请各位专家解答!
    • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
    • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
    • ¥30 截图中的mathematics程序转换成matlab
    • ¥15 动力学代码报错,维度不匹配