Как выполнить 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 должен быть именем файла, который вы хотите выполнить!