0

0

PHP命令行模式怎么用_PHPCLI脚本开发指南

雪夜

雪夜

发布时间:2025-09-30 13:55:02

|

882人浏览过

|

来源于php中文网

原创

PHP CLI模式可用于执行定时任务和数据处理,通过php命令运行脚本,支持传参($argv)、交互输入(fgets(STDIN)),建议添加Shebang、设置编码、使用exit状态码和STDERR输出错误。

php命令行模式怎么用_phpcli脚本开发指南

PHP 不只是用来做网页的,它也能通过命令行运行脚本,这就是 PHP 的 CLI(Command Line Interface)模式。相比 Web 模式,CLI 更适合执行定时任务、数据处理、自动化脚本等后台操作。下面带你快速掌握 PHP CLI 的基本用法和开发技巧。

什么是 PHP CLI

CLI 是 PHP 的命令行接口,允许你在终端或控制台中直接运行 PHP 脚本,不需要依赖 Web 服务器。你输入一条命令,PHP 解释器就会执行对应的脚本,并将结果输出到终端。

判断当前是否运行在 CLI 模式,可以用:

if (php_sapi_name() === 'cli') { ... }

这个判断常用于兼容 Web 和 CLI 双模式运行的脚本。

立即学习PHP免费学习笔记(深入)”;

如何运行 PHP CLI 脚本

打开终端,进入脚本所在目录,使用 php 命令加上脚本文件名即可运行:

  • php script.php —— 最基本的执行方式
  • php -f script.php —— 显式指定文件(可选)
  • php -r 'echo "Hello CLI";' —— 直接运行一行代码,不需文件

你还可以给脚本传参,就像其他命令一样:

php myscript.php arg1 arg2 arg3

这些参数会存入全局变量 $argv,其中 $argv[0] 是脚本名,$argv[1] 开始是传入的参数,总共个数为 $argc

MixPHP3.0.27
MixPHP3.0.27

MixPHP 是一个 PHP 命令行模式开发框架;基于 Vega 驱动的 HTTP 可以同时支持 Swoole、WorkerMan、FPM、CLI-Server 生态,并且可以无缝切换;V3 是一个高度解耦的版本,整体代码基于多个独立的模块构建,即便用户不使用我们的脚手架,也可以使用这些独立模块,并且全部模块都支持原生开发。例如:你可以只使用 mix/vega 来搭配 laravel orm 使用

下载

读取用户输入与交互

CLI 脚本可以和用户互动,比如提示输入账号密码或确认操作。常用方法是读取标准输入:

$handle = fopen("php://stdin", "r");
$input = trim(fgets($handle));
fclose($handle);

例如:

echo "确定要继续吗?(y/n): ";
$answer = trim(fgets(STDIN));
if ($answer === 'y') { echo "开始执行...\n"; }

注意:使用 STDIN 前确保是在 CLI 环境下,否则可能报错。

编写实用的 CLI 脚本技巧

写好 CLI 脚本有几个实用建议:

  • 加 Shebang 行:在脚本开头加上 #!/usr/bin/env php,Linux/Mac 下可直接 ./script.php 执行
  • 设置输出编码:避免乱码,可加 ini_set('default_charset', 'UTF-8');
  • 退出状态码:成功用 exit(0); 失败用 exit(1);,便于脚本调用判断结果
  • 日志输出到 stderr:错误信息用 fwrite(STDERR, "错误提示\n");,不影响正常输出流

示例脚本结构:

#!/usr/bin/env php
if ($argc fwrite(STDERR, "用法: php script.php \n");
exit(1);
}
echo "你好, " . $argv[1] . "\n";
exit(0);

基本上就这些。PHP CLI 模式简单直接,特别适合写运维脚本、队列处理、数据库迁移等任务。只要会写 PHP,再了解下命令行传参和输入输出,就能轻松上手。不复杂但容易忽略细节,比如参数解析和错误输出分流,写得规范些,后期维护更省心。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

775

2023.08.22

fclose函数的用法
fclose函数的用法

fclose是一个C语言和C++中的标准库函数,用于关闭一个已经打开的文件,是文件操作中非常重要的一个函数,用于将文件流与底层文件系统分离,释放相关的资源。更多关于fclose函数的相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

330

2023.11.30

fgets在c语言中的用法
fgets在c语言中的用法

本专题整合了c语言中fgets用法介绍,阅读专题下面的文章了解更多详细内容。

16

2025.08.27

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

78

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

96

2025.09.18

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1078

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

169

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1358

2025.12.29

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号