如何使用 PHP 页面中的 shell 脚本执行 MySQL 命令?

kut*_*iah 5 php mysql bash shell

我想从 php 页面执行一个 shell 脚本,它将执行一个 MySQL 命令。

为此,我按照此处显示的方式进行操作:https : //stackoverflow.com/a/8055745/2117868

这是我的 sqlscript.sh

#!/bin/sh
sudo wget -t 50 -O /tmp/update.sql http://example.com/update.sql
if [ $? -eq 0 ]; then
    mysql -h "localhost" -u "root" "-pXXXXXXXX" "database-name" < "/tmp/update.sql"
    if [ $? -eq 0 ]; then
        sudo rm /tmp/update.sql
        echo "200"
    else
        echo "502"
    fi
else
    echo "404"
fi
Run Code Online (Sandbox Code Playgroud)

我的 php 页面是 runscript.php

<?php
    shell_exec("sudo /path/to/script/sqlscript.sh");
?>
Run Code Online (Sandbox Code Playgroud)

现在,当我sqlscript.sh服务器控制台php 页面 调用runscript.php它时,它可以正常工作200并按预期返回。

但是当我输入 MYSQL 用户和密码时~/.my.cnf,我根本不必将它放在命令行上:

[client]
user = root
password = XXXXXXXX
Run Code Online (Sandbox Code Playgroud)

并添加凭据以在sudoer没有密码的情况下执行此脚本。

User_Alias WWW_USER = www-data
Cmnd_Alias WWW_COMMANDS_SQL = /path/to/script/sqlscript.sh
WWW_USER ALL = (ALL) NOPASSWD: WWW_COMMANDS_SQL
Run Code Online (Sandbox Code Playgroud)

这是我的 sqlscript.sh

#!/bin/sh
sudo wget -t 50 -O /tmp/update.sql http://example.com/update.sql
if [ $? -eq 0 ]; then
    mysql -h "localhost" "database-name" < "/tmp/update.sql"
    if [ $? -eq 0 ]; then
        sudo rm /tmp/update.sql
        echo "200"
    else
        echo "502"
    fi
else
    echo "404"
fi
Run Code Online (Sandbox Code Playgroud)

现在,当我sqlscript.sh服务器控制台调用它时,它可以正常工作200并按预期返回。但是如果我从 php 页面调用它

http://example.com/runscript.php
Run Code Online (Sandbox Code Playgroud)

它返回,502因为它无法执行 SQL 命令。

更新:

这是阿帕奇 error.log

--2014-12-05 10:51:55--  http://example.com/update.sql
Resolving example.com (example.com)... 162.144.71.XXX
Connecting to example.com (example.com)|162.144.71.XXX|:80... connected.
HTTP request sent, awaiting response... 200 OK
Length: 146 [text/x-sql]
Saving to: `/tmp/update.sql'

     0K                                                       100% 10.9M=0s

2014-12-05 10:51:55 (10.9 MB/s) - `/tmp/update.sql' saved [146/146]

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)
Run Code Online (Sandbox Code Playgroud)

所以,请帮我解决这个问题。

Don*_*joe 0

你试过这个吗?

在你的 shell 脚本中,而不是

mysql -h "localhost" "database-name" < "/tmp/update.sql"
Run Code Online (Sandbox Code Playgroud)

使用

mysql -h "localhost"-u root -ppassword "database-name" < "/tmp/update.sql"
Run Code Online (Sandbox Code Playgroud)

基本上,尝试在 shell 脚本中传递 MySQL 用户名和密码。当然,您可以将它们放入变量/配置/任何内容中以保护它

MySQL 28000 错误表明您的脚本能够尝试以 root 身份登录,但由于没有参数密码,因此失败