脚本宝典收集整理的这篇文章主要介绍了如何使用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
<?PHP shell_exec("sudo /path/to/script/sqlscript.sh"); ?>
现在,当我从服务器控制台或PHP页面runcript.PHP调用sqlscript.sh时,它完美地运行并按预期返回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
更新:
--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)
所以,请帮我解决这个问题.
以上是脚本宝典为你收集整理的如何使用PHP页面中的shell脚本执行MySQL命令?全部内容,希望文章能够帮你解决如何使用PHP页面中的shell脚本执行MySQL命令?所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。