>백엔드 개발 >PHP 튜토리얼 >PHP 명령줄 실행에 대한 자세한 설명

PHP 명령줄 실행에 대한 자세한 설명

小云云
小云云원래의
2018-03-10 11:55:254682검색

다음은 PHP 바이너리 파일(즉, php.exe 프로그램)에서 제공하는 명령줄 모드 옵션 매개변수입니다. PHP -h 명령을 통해 언제든지 이러한 매개변수를 쿼리할 수 있습니다.

<span style="font-size: 14px;">Usage: php [options] [-f] 28897b20adb25fbae118a3f80f538dec [args...]<br>       php [options] -r ffbe95d20f3893062224282accb13e8f [args...]<br>       php [options] [-- args...]<br>  -s               Display colour syntax highlighted source.<br>  -w               Display source with stripped comments and whitespace.<br>  -f 28897b20adb25fbae118a3f80f538dec        Parse 28897b20adb25fbae118a3f80f538dec.<br>  -v               Version number<br>  -c 98953a78f52873edae60a617ec082494|28897b20adb25fbae118a3f80f538dec Look for php.ini file in this directory<br>  -a               Run interactively<br>  -d foo[=bar]     Define INI entry foo with value 'bar'<br>  -e               Generate extended information for debugger/profiler<br>  -z 28897b20adb25fbae118a3f80f538dec        Load Zend extension 28897b20adb25fbae118a3f80f538dec.<br>  -l               Syntax check only (lint)<br>  -m               Show compiled in modules<br>  -i               PHP information<br>  -r ffbe95d20f3893062224282accb13e8f        Run PHP ffbe95d20f3893062224282accb13e8f without using script tags e1cdf277302c20b8d8f1b523c1353fef<br>  -h               This help<br> <br>  args...          Arguments passed to script. Use -- args when first argument <br>                   starts with - or script is read from stdin<br></span>

CLI SAPI 모듈에는 실행하려는 PHP 코드를 가져오는 다음 세 가지 방법이 있습니다.

Windows 환경에서는 큰따옴표를 사용해 보세요. Linux 환경에서는 사용해 보세요. 작은따옴표를 사용하여 완료합니다.

  1. PHP가 지정된 파일을 실행하도록 합니다.

    <span style="font-size: 14px;">php my_script.php <br/>php -f  "my_script.php"<br/></span>

    위의 두 방법 모두(-f 매개변수 유무에 관계없이) 주어진 my_script.php 파일을 실행할 수 있습니다. 실행할 파일을 선택할 수 있습니다. 지정하는 PHP 스크립트에는 .php 확장자가 없어도 됩니다.

  2. 명령줄에서 직접 PHP 코드를 실행하세요.

    <span style="font-size: 14px;">php -r "print_r(get_defined_constants());"<br/></span>

    이 방법을 사용할 때 쉘 변수 대체와 따옴표 사용에 주의하시기 바랍니다.

    참고: 위의 예를 주의 깊게 읽어보세요. 코드를 실행할 때 시작 및 끝 표시가 없습니다! -r 매개변수를 사용하면 이러한 표시가 필요하지 않으며 구문 오류가 발생합니다.

  3. 표준 입력(stdin)을 통해 실행해야 하는 PHP 코드를 제공하세요.

    위 사용법은 매우 강력한 기능을 제공하므로 다음 예와 같이 PHP 코드를 동적으로 생성하고 명령줄을 통해 이러한 코드를 실행할 수 있습니다. 위의 세 가지 코드 실행 방법은 동시에 사용할 수 없습니다.

    모든 셸 애플리케이션과 마찬가지로 PHP 바이너리(php.exe 파일)와 이 애플리케이션이 실행하는 PHP 스크립트는 일련의 매개변수를 받아들일 수 있습니다. PHP는 스크립트에 전달되는 인수 수에 제한이 없습니다(셸에는 명령줄의 문자 수에 제한이 있지만 일반적으로 이 제한을 초과하지 않습니다). 스크립트에 전달된 인수는 전역 변수 $argv에서 사용할 수 있습니다. 이 배열의 인덱스가 0인 멤버는 스크립트의 이름입니다(PHP 코드가 표준 입력에서 제공되고 -r 매개변수를 사용하여 명령줄에서 직접 실행되는 경우 이름은 "-"입니다). 또한 전역 변수 $argc는 $argv 배열의 멤버 변수 수를 저장합니다(스크립트 프로그램에 전달된 매개변수 수가 아님). 스크립트에 보내는 매개변수가 - 기호로 시작하지 않는 한, 어떤 것에도 너무 많은 주의를 기울일 필요가 없습니다. -로 시작하는 매개변수를 스크립트에 전달하면 PHP가 이러한 매개변수를 자체적으로 처리해야 한다고 생각하기 때문에 오류가 발생합니다. 이 문제를 해결하려면 매개변수 목록 구분 기호를 사용할 수 있습니다. PHP가 매개변수를 구문 분석한 후 이 기호 뒤의 모든 매개변수는 그대로 스크립트에 전달됩니다.

$ some_application | some_filter | php | sort -u >final_output.txt

除此之外,我们还有另一个方法将 PHP 用于外壳脚本。您可以在写一个脚本,并在第一行以 #!/usr/bin/php 开头,在其后加上以 PHP 开始和结尾标记符包含的正常的 PHP 代码,然后为该文件设置正确的运行属性。该方法可以使得该文件能够像外壳脚本或 PERL 脚本一样被直接执行。

#!/usr/bin/php
efed5127f36b981c4500e1430988f65b

假设改文件名为 test 并被放置在当前目录下,我们可以做如下操作:

<span style="font-size: 14px;">$ chmod 755 test<br/>$ ./test -h -- foo<br/>array(4) {<br/>  [0]=><br/>  string(6) "./test"<br/>  [1]=><br/>  string(2) "-h"<br/>  [2]=><br/>  string(2) "--"<br/>  [3]=><br/>  string(3) "foo"<br/>}<br/></span>

보시다시피 -로 시작하는 매개변수를 스크립트에 전달해도 스크립트는 여전히 정상적으로 실행됩니다.

표 23-3. 명령줄 옵션

옵션 이름 설명
-s

구문 강조 색상 소스와 함께 표시됨 파일.

이 매개변수는 내장 메커니즘을 사용하여 파일을 구문 분석하고 HTML 강조 버전을 생성한 후 결과를 표준 출력에 기록합니다. 이 모든 프로세스는 ffbe95d20f3893062224282accb13e8f [...] 1cd55414ff5abdfea5dd958e7e547fdd HTML 태그 블록을 생성하는 것뿐이며 HTML 헤더는 포함하지 않습니다.

참고: 이 옵션은 -r 매개변수와 함께 사용할 수 없습니다.

-w

은 주석과 공백이 제거된 소스 코드를 보여줍니다.

참고: 이 옵션은 -r 매개변수와 함께 사용할 수 없습니다.

-f

주어진 파일 이름을 구문 분석하고 실행합니다. 이 매개변수는 선택사항이며 생략할 수 있습니다. 실행해야 하는 파일의 이름만 지정하면 됩니다.

-v

PHP, PHP SAPI, Zend의 버전 정보를 표준 출력에 씁니다. 예:

$ php -v PHP 4.3.0-dev(cli), 저작권(c) 1997-2002 PHP 그룹 Zend Engine v1.3.0, Copyright (c) 1998-2002 Zend Technologies
-c

이 매개변수를 사용하면 php.ini 파일이 있는 디렉토리를 지정하거나 직접 지정할 수 있습니다. 사용자 정의 INI 파일을 만들려면 해당 파일 이름이 php.ini가 아닐 수 있습니다. 예:

$ php -c /custom/directory/ my_script.php $ php -c /custom/directory/custom-file.ini my_script.php
-a

PHP를 대화형으로 실행합니다.

-d

이 매개변수를 사용하여 php.ini 파일의 변수 값을 설정합니다. 구문은 다음과 같습니다.

# 값 부분을 생략하면 주어진 구성 지시문이 "1"로 설정됩니다. $ php -d max_execution_time -r '$foo = ini_get("max_execution_time");' 문자열(1) "1" # 빈 값 부분을 전달하면 구성 지시문이 ""로 설정됩니다. php -d max_execution_time= -r '$foo = ini_get("max_execution_time");' 문자열(0) "" # 구성 지시문은 '=' 문자 뒤에 전달되는 모든 항목으로 설정됩니다. $ php -d max_execution_time=20 -r '$foo = ini_get("max_execution_time");' 문자열(2) "20" $ PHP -d max_execution_time=이해가 되지 않습니다 -r '$foo = ini_get("max_execution_time");' string(15) "doesntmakesense"
-e

디버거 등에 대한 확장 정보를 생성합니다.

-z

Zend 확장 라이브러리를 로드합니다. 파일 이름만 제공되면 PHP는 시스템 확장 라이브러리의 기본 경로(Linux 시스템에서 이 경로는 일반적으로 /etc/ld.so.conf에 지정됨)에서 확장 라이브러리를 로드하려고 시도합니다. 절대 경로로 파일 이름을 지정하면 확장 라이브러리에 대한 시스템의 기본 경로가 사용되지 않습니다. 상대 경로로 파일 이름을 지정하면 PHP는 현재 디렉터리에 상대적인 확장만 로드하려고 시도합니다.

-l

이 매개변수는 지정된 PHP 코드의 구문을 검사하는 편리한 방법을 제공합니다. 성공하면 2334ac29606bf8a170583e4f7533b1f4에서 발견된 구문 오류 없음 문자열이 표준 출력에 기록되고 셸은 값 0을 반환합니다. 실패하면 2334ac29606bf8a170583e4f7533b1f4 구문 분석 오류가 내부 구문 분석기 오류 메시지와 함께 표준 출력에 기록되고 셸 반환 값은 255로 설정됩니다.

이 매개변수는 치명적인 오류(예: 정의되지 않은 함수)를 확인할 수 없습니다. 치명적인 오류를 감지하려면 -f 매개변수를 사용하세요.

참고: 이 매개변수는 -r과 함께 사용할 수 없습니다.

-m

이 매개변수를 사용하면 PHP는 내장 및 로드된 PHP와 Zend 모듈을 인쇄합니다:

$ php -m [PHP 모듈] xml 토크나이저 기준 세션 포식스 pcre 초과 적재 mysql mbstring ctype [Zend 모듈]
-i 이 명령줄 매개변수는 phpinfo() 함수를 호출하고 결과를 인쇄합니다. PHP가 제대로 작동하지 않으면 PHP를 실행하는 것이 좋습니다 -i 정보 테이블 앞이나 해당 위치에 오류 메시지 출력이 있는지 확인하는 명령입니다. 출력 내용이 HTML 형식이므로 출력 정보가 ​​더 크다는 점에 유의하시기 바랍니다.
-r

명령줄에서 PHP 코드를 실행하려면 이 매개변수를 사용하세요. PHP 시작 및 끝 식별자(16356d1f61fff5d20d424e8a965fac77)를 추가할 필요가 없습니다. 그렇지 않으면 구문 분석 오류가 발생합니다.

注: 使用这种形式的 PHP 时,应个别注意避免和外壳环境进行的命令行参数替换相冲突。

显示语法解析错误的范例

$ php -r "$foo = get_defined_constants();" Command line code(1) : Parse error - parse error, unexpected '='

这里的问题在于即时使用了双引号 ",sh/bash 仍然实行了参数替换。由于 $foo 没有被定义,被替换后它所在的位置变成了空字符,因此在运行时,实际被 PHP 读取的代码为:

$ php -r " = get_defined_constants();"

正确的方法是使用单引号 '。在用单引号引用的字符串中,变量不会被 sh/bash 还原成其原值。

$ php -r '$foo = get_defi
<br/>
ned_constants(); var_dump($foo);' array(370) {  ["E_ERROR"]=>  int(1)  ["E_WARNING"]=>  int(2)  ["E_PARSE"]=>  int(4)  ["E_NOTICE"]=>  int(8)  ["E_CORE_ERROR"]=>  [...]

如果您使用的外壳不是 sh/bash,您可能会碰到其它的问题。请报告您碰到的 bug,或者发邮件到 phpdoc@lists.php.net。

当您试图将外壳的环境变量引入到马或者用反斜线来转义字符时也可能碰到各种各样的问题,请您在使用时注意!

注: -r 在 CLI SAPI 中有效,在 CGI SAPI 中无效。

-h 使用该参数,您可以得到完整的命令行参数的列表及这些参数作用的简单描述。


PHP 的命令行模式能使得 PHP 脚本能完全独立于 WEB 服务器单独运行。如果您使用 Unix 系统,您需要在您的 PHP 脚本的最前面加上一行特殊的代码,使得它能够被执行,这样系统就能知道用什么样的程序要运行该脚本。在 Windows 平台下您可以将 php.exe 和 .php 文件的双击属性相关联,您也可以编写一个批处理文件来用 PHP 执行脚本。为 Unix 系统增加的第一行代码不会影响该脚本在 Windows 下的运行,因此您也可以用该方法编写跨平台的脚本程序。以下是一个简单的PHP 命令行程序的范例。

例子 23-1. 试图以命令行方式运行的 PHP 脚本(script.php)

#!/usr/bin/php82c68971946bf05db3b94f3b927e3c17This is a command line PHP script with one option.  Usage:  6925e5facaaf6ccc7a8ba2dfb2f25106 5a07473c87748fb1bf73f23d45547ab8  5a07473c87748fb1bf73f23d45547ab8 can be some word you would like  to print out. With the --help, -help, -h,  or -? options, you can get this help.6d411e2bbda1d098e47f09cda7e0e03e

위 스크립트에서는 첫 번째 특수 코드 줄을 사용하여 파일이 PHP로 실행되어야 함을 나타냅니다. 여기서는 CLI 버전을 사용하고 있으므로 HTTP 헤더가 출력되지 않습니다. PHP에서 명령줄 애플리케이션을 작성할 때 $argc 및 $argv라는 두 가지 매개변수를 사용할 수 있습니다. 이전 값은 매개변수 개수보다 1 큰 정수입니다(실행 중인 스크립트의 이름도 매개변수로 간주됩니다). 두 번째 요소에는 매개변수 배열이 포함되어 있으며 첫 번째 요소는 스크립트 이름이고 아래 첨자는 숫자 0($argv[0])입니다.

위 프로그램에서는 매개변수의 개수가 1보다 큰지, 1보다 작은지 확인했습니다. 매개변수가 --help, -help, -h 또는 -?인 경우에도 도움말 정보를 인쇄하는 동시에 스크립트 이름을 동적으로 출력합니다. 다른 매개변수가 수신되면 해당 매개변수도 표시합니다.

위 스크립트를 Unix에서 실행하려면 실행 가능한 스크립트로 만든 다음 script.php echothis 또는 script.php -h를 실행하면 됩니다. Windows에서는 다음을 위한 배치 파일을 작성할 수 있습니다.

관련 권장 사항:

명령줄 기반 매개변수를 사용하여 PHP 스크립트를 실행하고 매개변수를 가져오는 방법

php 스크립트 실행 명령줄 기반 매개변수 사용 매개변수화된 PHP 스크립트 및 매개변수 획득 방법, PHP 스크립트_PHP 튜토리얼

PHP에서 명령줄 실행

위 내용은 PHP 명령줄 실행에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.