Anwendung von CURL und PHP-CLI [CLI]
CLI的普通应用
什么是PHP-CLI
php-cli是php Command Line Interface的简称,即PHP命令行接口,在windows和linux下都是支持PHP-CLI模式的;
为什么要使用PHP-CLI
- 多线程应用
- 定时执行php程序
- 开发桌面程序 (使用PHP-CLI和GTK包即可开发桌面,但没人会用PHP来编写桌面程序的)
- 编写PHP的shell脚本
判断PHP运行模式
PHP的运行模式远远不止apache和cli,还包括:olserver, apache, apache2filter, apache2handler, caudium, cgi (until PHP 5.3), cgi-fcgi, cli, continuity, embed, isapi, litespeed, milter, nsapi, phttpd, pi3web, roxen, thttpd, tux, and webjames.
<code>echo php_sapi_name(); //如果是CLI模式下访问就输出CLI,如果是Apache就是apache2handler... </code>
PHP-CLI 内置参数
<code>D:\wamp\bin\php\php5.3.8>php -help
Usage: php [options] [-f] <file> [--] [args...]
php [options] -r <code> [--] [args...]
php [options] [-B <begin_code>] -R <code> [-E <end_code>] [--] [args...]
php [options] [-B <begin_code>] -F <file> [-E <end_code>] [--] [args...]
php [options] -- [args...]
php [options] -a
-a Run interactively
-c <path>|<file> Look for php.ini file in this directory
-n No php.ini file will be used
-d foo[=bar] Define INI entry foo with value 'bar'
-e Generate extended information for debugger/profiler
-f <file> Parse and execute <file>.
-h This help
-i PHP information
-l Syntax check only (lint)
-m Show compiled in modules
-r <code> Run PHP <code> without using script tags <?..?>
-B <begin_code> Run PHP <begin_code> before processing input lines
-R <code> Run PHP <code> for every input line
-F <file> Parse and execute <file> for every input line
-E <end_code> Run PHP <end_code> after processing all input lines
-H Hide any passed arguments from external tools.
-s Output HTML syntax highlighted source.
-v Version number
-w Output source with stripped comments and whitespace.
-z <file> Load Zend extension <file>.
args... Arguments passed to script. Use -- args when first argument
starts with - or script is read from stdin
--ini Show configuration file names
--rf <name> Show information about function <name>.
--rc <name> Show information about class <name>.
--re <name> Show information about extension <name>.
--ri <name> Show configuration for extension <name>.</code>
- 运行指定的php文件:
<code><?php echo 'this is php-cli' ?></code>
<code># php /var/www/html/test.php this is a php-cli [root@semple html]# php -f 'test.php' this is a php-cli</code>
- 在命令行直接运行 PHP 代码
<code>D:\wamp\bin\php\php5.3.8>php -r "echo 'hello world';" hello world</code>
注意: 在运行这些php代码时没有开始和结束的标记符!加上
-r参数后,这些标记符是不需要的,加上它们会导致语法错误。
- 通过标准输入(stdin)提供需要运行的 PHP 代码
<code>// ask for input fwrite(STDOUT, "Enter your name: "); // get input $name = trim(fgets(STDIN)); // write input back fwrite(STDOUT, "Hello, $name!");</code>
<code>D:\wamp\www>php test.php Enter your name: D:\wamp\www>php test.php Enter your name: zhouzhou Hello, zhouzhou!</code>
获取自定义参数
<code>print_r($argv); //获取具体的参数; print_r($argc); //获取参数的数目;</code>
<code>D:\wamp\www>php test.php #本身执行的php文件就作为一个参数;
Array
(
[0] => test.php
)
1
D:\wamp\www>php test.php arg1 arg2 arg3 arg4
Array
(
[0] => test.php
[1] => arg1
[2] => arg2
[3] => arg3
[4] => arg4
)
5</code>
argv和argc也分别可以在$_SERVER数组中得到
<code><?php $args = getopt('g:m:a:'); //只能是单个单词,如果不是单个单词就会出错; print_r($args); ?></code>
<code>D:\wamp\www>php test.php -g group -m module -a age
Array
(
[g] => group
[m] => module
[a] => age
)</code>
PHP-CLI在框架中的应用
首先要清楚,大多数PHP-CLI都是在crontab中应用,俗称'跑脚本'。既然是'跑',那肯定是一个庞大的IO开销,这个时候放在框架环境中来跑这个脚本的话,至少我的使用过程中遇见过'内存泄漏',php这种语言基本上不会遇见的情况就是在这种情况下遇见的;
- 在CI框架中应用
<code># php /var/www/html/web2/index.php welcome test 这个是在ci里面执行的welcome控制器里面的test方法,后面的以此类推;</code>
还可以代入变量
<code><?php
class Tools extends CI_Controller {
public function message($to = 'World')
{
echo "Hello {$to}!".PHP_EOL;
}
}
?></code>
<code>$ cd /path/to/project; $ php index.php tools message # Hello John Smith!。</code>
- 在TP框架中的应用
在thinkphp中对CLI的支持并非很好,但我们可以通过$argv在框架运行之初就自动组成相应的g,m,a等get变量;甚至另开其一个只能是cli模式访问文件
<code>//如果是CLI模式
if(php_sapi_name() === 'cli'){
//检测CLI访问时没有带自定义参数;
$path = isset($argv[1]) ? $argv[1] : '';
$depr = '/';
if (!empty($path)) {
$params = explode($depr , trim($path , $depr));
}
!empty($params) ? $_GET['g'] = array_shift($params) : "";
!empty($params) ? $_GET['m'] = array_shift($params) : "";
!empty($params) ? $_GET['a'] = array_shift($params) : "";
if ($params and count($params) > 1) {
// 解析剩余参数 并采用GET方式获取
preg_replace('@(\w+),([^,\/]+)@e' , '$_GET[\'\\1\']="\\2";' , implode(',' , $params));
}
/*
D:\wamp\www\sx>D:\wamp\bin\php\php5.3.8/php cli.php group/module/action/a1/v1/a2/v2
Array
(
[g] => group
[m] => module
[a] => action
[a1] => v1
[a2] => v2
)
*/
// print_r($_GET);
// die;
}</code>
PHP-CLI来写shell脚本
PHP与Linux命令交互的几个函数
exec
<code>string exec ( string $command [, array &$output [, int &$return_var ]] )
echo exec('mkdir -p zhouzhou/1/2/3/') ."\n"; //创建目录树
echo exec('ls -l',$fileList) ; //本句只能输出最后一条,但如果有第二个参数的话,就可以把输出的结果作为数组元素扔进去;
echo "<pre />";
print_r($fileList); //把所有ls -l的结果都给了$fileList;
echo "<pre />";
die;</code>
shell_exec
<code>string shell_exec ( string $cmd )
$fileList = shell_exec('ls -l'); //$fileList是一个string格式,就等于linux命令在终端输出的格式,保留了\s\n等换行符</code>
system
<code>string system ( string $command [, int &$return_var ] )
$fileList = system('ls -l') ; //本句只能输出最后一条,但如果有第二个参数的话,就可以把输出的结果作为数组元素扔进去;</code>
passthru
<code>void passthru ( string $command [, int &$return_var ] )
passthru('ls -l'); //直接执行并输出</code>
popen
<code>resource popen ( string $command , string $mode )
/*
返回一个和 fopen() 所返回的相同的文件指针,只不过它是单向的(只能用于读或写)并且必须用 pclose() 来关闭。此指针可以用于 fgets(),fgets() 和 fwrite()。 当模式为 'r',返回的文件指针等于命里的 STDOUT,当模式为 'w',返回的文件指针等于命令的 STDIN。
如果出错返回 FALSE。
*/
$fp = popen('ls -l',"r"); //popen打一个进程通道
while (!feof($fp)) {
$out = fgets($fp, 4096);
echo $out; //输出的结果和passthru是一样的;不过要循环的取出来;
}
pclose($fp); </code>
proc_open
<code>resource proc_open ( string $cmd , array $descriptorspec , array &$pipes [, string $cwd [, array $env [, array $other_options ]]] )
$test = "ls";
$array = array(
array("pipe","r"), //标准输入
array("pipe","w"), //标准输出内容
array("pipe","w") //标准输出错误
);
$fp = proc_open($test,$array,$pipes); //打开一个进程通道
echo stream_get_contents($pipes[1]); //为什么是$pipes[1],因为1是输出内容
proc_close($fp);
//类似 popen() 函数, 但是 proc_open() 提供了更加强大的控制程序执行的能力。</code>
以上就介绍了CURL与PHP-CLI的应用【CLI篇】,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
Heiße KI -Werkzeuge
Undress AI Tool
Ausziehbilder kostenlos
Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos
AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.
Clothoff.io
KI-Kleiderentferner
Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!
Heißer Artikel
Heiße Werkzeuge
Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor
SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen
Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung
Dreamweaver CS6
Visuelle Webentwicklungstools
SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)
Heiße Themen
Eine einfache Anleitung zum PHP -Setup
Jul 18, 2025 am 04:25 AM
Der Schlüssel zum Einrichten von PHP besteht darin, die Installationsmethode zu klären, PHP.ini zu konfigurieren, eine Verbindung zum Webserver herzustellen und die erforderlichen Erweiterungen zu aktivieren. 1. Installieren Sie PHP: Verwenden Sie APT für Linux, Homebrew für Mac und XAMPP für Windows. 2. Konfigurieren Sie Php.ini: Fehlerberichte anpassen, Einschränkungen hochladen und den Server neu starten. 3. Verwenden Sie Webserver: Apache verwendet mod_php, nginx verwendet PHP-FPM. V.
Code in PHP aus dem Code ausgehen
Jul 18, 2025 am 04:57 AM
Es gibt drei gängige Methoden für den PHP -Kommentarcode: 1. Verwenden Sie // oder #, um eine Codezeile zu blockieren, und es wird empfohlen, // zu verwenden. 2. Verwenden Sie /.../, um Codeblöcke mit mehreren Zeilen zu wickeln, die nicht verschachtelt werden können, aber gekreuzt werden können. 3.. Kombinationskenntnisse Kommentare wie die Verwendung / if () {} / Um Logikblöcke zu steuern oder um die Effizienz mit Editor -Verknüpfungsschlüssel zu verbessern, sollten Sie auf die Schließung von Symbolen achten und das Verschachteln bei der Verwendung vermeiden.
SchnellpHP -Installations -Tutorial
Jul 18, 2025 am 04:52 AM
Toinstallphpquickly, usexampponwindowsorhomebrewonmacos.1.onwindows, download undInstallxampp, SelectComponents, Startapache und PlaceFilesinhtdocscs.2.Anternativ, manuellinstallphpfrfr
Schreiben effektiver PHP -Kommentare
Jul 18, 2025 am 04:44 AM
Kommentare können nicht nachlässig sein, da sie die Gründe für die Existenz des Codes und nicht die Funktionen erklären möchten, z. B. die Kompatibilität mit alten Schnittstellen oder Einschränkungen von Drittanbietern, sonst können Personen, die den Code lesen, nur auf Vermutungen angewiesen. Die Bereiche, die kommentiert werden müssen, umfassen komplexe bedingte Urteile, spezielle Fehlerbehandlungslogik und vorübergehende Bypass -Beschränkungen. Eine praktischere Möglichkeit, Kommentare zu schreiben, besteht darin, Einzelzeilen-Kommentare auszuwählen oder Kommentare basierend auf der Szene zu blockieren. Verwenden Sie Dokumentblock Kommentare, um Parameter zu erläutern und Werte zu Beginn von Funktionen, Klassen und Dateien zurückzugeben, und halten Sie die Kommentare aktualisiert. Für eine komplexe Logik können Sie dem vorherigen eine Zeile hinzufügen, um die Gesamtabsicht zusammenzufassen. Verwenden Sie gleichzeitig keine Kommentare zum Versiegelungscode, sondern verwenden Sie Versionsteuerungswerkzeuge.
Verbesserung der Lesbarkeit mit Kommentaren
Jul 18, 2025 am 04:46 AM
Der Schlüssel zum Schreiben guter Kommentare besteht darin, "warum" zu erklären, anstatt nur "was getan wurde", um die Lesbarkeit des Codes zu verbessern. 1. Kommentare sollten logische Gründe erklären, wie z. B. Überlegungen für die Wertauswahl oder -verarbeitung; 2. Verwenden Sie Absatzanmerkungen für eine komplexe Logik, um die Gesamtidee von Funktionen oder Algorithmen zusammenzufassen. Fegen regelmäßig Kommentare beibehalten, um die Konsistenz mit dem Code zu gewährleisten, irreführend und gegebenenfalls veraltete Inhalte zu löschen. V.
Tipps zum Schreiben von PHP -Kommentaren
Jul 18, 2025 am 04:51 AM
Der Schlüssel zum Schreiben von PHP -Kommentaren liegt in der Klärung des Zwecks und der Spezifikationen. Kommentare sollten "Warum" und nicht "was getan" erklären, um Redundanz oder zu Einfachheit zu vermeiden. 1. Verwenden Sie ein einheitliches Format wie Docblock (/*/) für Klassen- und Methodenbeschreibungen, um die Lesbarkeit und die Kompatibilität der Werkzeuge zu verbessern. 2. Betonen Sie die Gründe für die Logik, z. B. warum JS -Sprünge manuell ausgeben müssen. 3. Fügen Sie eine Übersichtsbeschreibung vor komplexem Code hinzu, beschreiben Sie den Prozess in Schritten und helfen Sie, die Gesamtidee zu verstehen. V. Gute Anmerkungen können die Kommunikationskosten senken und die Effizienz der Code -Wartung verbessern.
PHP lernen: Ein Anfängerführer
Jul 18, 2025 am 04:54 AM
Tolearnphpeffectival, startbysettingupalocalerverenVironmentusexs -LikexamppandacodeeditorikevScode.1) InstallxamppForapache, MySQL und Php.SeacodeeditorForsyntaxSupport.3) testyourscludingveliktingveliktelaThbiliodble.Neclyble.NektFile
Mastering von PHP -Block -Kommentaren beherrschen
Jul 18, 2025 am 04:35 AM
PhpblockComentsuEsfulforwritingMulti-linexplanationen, vorübergehend absorbierendeCode und GeneratingDocumentation


