Как выполнить PHP-скрипт из другого PHP-скрипта с помощью оболочки?
у меня есть файл php под названием sample.php
следующего содержания:
<?php
echo "Hello World!";
?>
и то, что я хочу сделать, это запустить этот PHP скрипт, использующий второй PHP-скрипт.
Я думаю shell_exec
могли бы мне помочь, но я не знаю его синтаксиса.
кстати, я хочу выполнить эти файлы с помощью cpanel
. Поэтому я должен выполнить оболочку.
есть ли способ сделать это?
7 ответов
Если вам нужно записать вывод php-файла в переменную, используйте функции ob_start и ob_get_contents. См. ниже:
<?php
ob_start();
include('myfile.php');
$myStr = ob_get_contents();
ob_end_clean();
echo '>>>>' . $myStr . '<<<<';
?>
Итак, если ваш " myfile.php ' содержит следующее:
<?php
echo 'test';
?>
тогда ваш выход будет:
>>>>test<<<<
вы можете использовать cURL для удаленных запросов. Ниже от php.net:
<?php
// create a new cURL resource
$ch = curl_init();
// set URL and other appropriate options
curl_setopt($ch, CURLOPT_URL, "http://www.example.com/");
curl_setopt($ch, CURLOPT_HEADER, 0);
// grab URL and pass it to the browser
curl_exec($ch);
// close cURL resource, and free up system resources
curl_close($ch);
?>
вот хороший учебник:http://www.sitepoint.com/using-curl-for-remote-requests/
рассмотрите возможность просмотра этого видео YouTube здесь:http://www.youtube.com/watch?v=M2HLGZJi0Hk
вы можете попробовать это:
основной файл PHP
<?php
// change path/to/php according to how your system is setup
// examples: /usr/bin/php or /opt/lampp/bin/php
echo shell_exec("/path/to/php /path/to/php_script/script.php");
echo "<br/>Awesome!!!"
?>
вторичный файл PHP
<?php
echo "Hello World!";
?>
вывод при запуске основного файла PHP
Hello World!
Awesome!!!
надеюсь, это поможет вам.
попробуйте это:
<?php
// change path/to/php according to how your system is setup
// examples: /usr/bin/php or /opt/lampp/bin/php
$output = shell_exec("/path/to/php /path/to/php_script/script.php");
print_r($output);
?>
Это может помочь вам.
важно подчеркнуть, что включение/выполнение пользовательского кода опасно. Использование системного вызова (exec
, shell_exec
, system
) вместо include
помогает отделить контекст выполнения, но это не намного безопаснее. Подумайте о надлежащей санитарии или песочнице.
имея это в виду, вот рабочий пример, включая создание (временного) файла, его выполнение и очистку:
<?php
// test content
$code = <<<PHP
echo "test";
PHP;
// create temporary file
$d=rand();
$myfile="$d.php";
file_put_contents($myfile,"<?php\n$code\n?>");
// start capture output
ob_start();
// include generate file
// NOTE: user-provided code is unsafe, they could e.g. replace this file.
include($myfile);
// get capture output
$result = ob_get_clean();
// remove temporary file
unlink($myfile);
// output result
echo "================\n" . $result . "\n================\n" ;
выход:
================
test
================
terminal view:
abgth@ubuntu:/var/www$ cat > test.php
<?php
echo shell_exec("php5 /var/www/check.php");
?>
abgth@ubuntu:/var/www$ cat > check.php
<?php
echo 'hi';
?>
abgth@ubuntu:/var/www$ php5 test.php
hi
Я надеюсь, что вы ищете этот
перейдите в терминал и введите
имя файла php.в PHP
именем.php должен быть именем файла, который вы хотите выполнить!