gpt4 book ai didi

php - 如何从 PHP 页面使用 shell 脚本执行 MySQL 命令?

转载 作者:可可西里 更新时间:2023-11-01 07:39:30 25 4
gpt4 key购买 nike

我想从将执行 MySQL 命令的 php 页面执行 shell 脚本。

为此,我按照此处显示的方式进行操作: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

我的 php 页面是 runscript.php

<?php
shell_exec("sudo /path/to/script/sqlscript.sh");
?>

现在,当我调用 sqlscript.sh服务器控制台php页面 runscript.php它完美运行并返回 200正如预期的那样。

但是当我在 ~/.my.cnf 中获取 MYSQL 用户和密码时所以我根本不必把它放在命令行上:

[client]
user = root
password = XXXXXXXX

并在 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

这是我的 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

现在,当我调用 sqlscript.sh服务器控制台它完美地工作并返回200正如预期的那样。但是如果我从 php 页面调用它

http://example.com/runscript.php

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

更新:

这是 Apache 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)

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

最佳答案

通过添加 --defaults-extra-file 选项解决。
mysql --defaults-extra-file=~/.my.cnf ...

或使用绝对路径(可能需要通过 apache,取决于服务器配置):
mysql --defaults-extra-file=/absolute/path/to/.my.cnf ...

关于php - 如何从 PHP 页面使用 shell 脚本执行 MySQL 命令?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27312258/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com