>  기사  >  백엔드 개발  >  PHP에서 명령줄 실행

PHP에서 명령줄 실행

不言
不言원래의
2018-05-09 11:56:331981검색

이 글은 주로 PHP에서의 명령줄 실행을 소개하는데, 이는 특정 참조 값을 가지고 있습니다. 이제는 모든 사람과 공유합니다. 도움이 필요한 친구들이 참고할 수 있습니다

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

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

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

Windows 환경에서는 큰따옴표를 사용하고 Linux에서는 환경에서는 큰따옴표를 사용하여 완료하세요.

  1. 지정된 파일을 PHP 실행해 보세요.

    php my_script.php 
    php -f  "my_script.php"

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

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

    php -r "print_r(get_defined_constants());"

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


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

  2. 표준 입력(stdin)을 통해 실행해야 하는 PHP 코드를 제공합니다.

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

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

以上三种运行代码的方法不能同时使用。

和所有的外壳应用程序一样,PHP 的二进制文件(php.exe 文件)及其运行的 PHP 脚本能够接受一系列的参数。PHP 没有限制传送给脚本程序的参数的个数(外壳程序对命令行的字符数有限制,但您通常都不会超过该限制)。传递给您脚本的参数可在全局变量 $argv 中获取。该数组中下标为零的成员为脚本的名称(当 PHP 代码来自标准输入获直接用 -r 参数以命令行方式运行时,该名称为“-”)。另外,全局变量 $argc 存有 $argv 数组中成员变量的个数(而非传送给脚本程序的参数的个数)。

只要您传送给您脚本的参数不是以 - 符号开头,您就无需过多的注意什么。向您的脚本传送以 - 开头的参数会导致错误,因为 PHP 会认为应该由它自身来处理这些参数。您可以用参数列表分隔符 -- 来解决这个问题。在 PHP 解析完参数后,该符号后所有的参数将会被原样传送给您的脚本程序。

# 以下命令将不会运行 PHP 代码,而只显示 PHP 命令行模式的使用说明:
$ php -r &#39;var_dump($argv);&#39; -h
Usage: php [options] [-f] <file> [args...]
[...]
 
# 以下命令将会把“-h”参数传送给脚本程序,PHP 不会显示命令行模式的使用说明:
$ php -r "var_dump($argv);" -- -h
array(2) {
  [0]=>
  string(1) "-"
  [1]=>
  string(2) "-h"
}

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

#!/usr/bin/php
<?php
    var_dump
($argv);
?>
<span style="color:rgb(0,0,0);"><span style="color:rgb(0,0,187);"></span></span>

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

$ chmod 755 test
$ ./test -h -- foo
array(4) {
  [0]=>
  string(6) "./test"
  [1]=>
  string(2) "-h"
  [2]=>
  string(2) "--"
  [3]=>
  string(3) "foo"
}

보시다시피 -로 시작하는 매개변수를 스크립트에 전달하면 스크립트가 계속 정상적으로 실행됩니다.

-------------------------------------------------- --- ---------------------명령 옵션------------ ------ -----------------------

표 23-3. 명령줄 옵션

옵션 이름 Description
-s

소스 파일을 구문 강조로 표시합니다.

이 매개변수는 내장 메커니즘을 사용하여 파일을 구문 분석하고 HTML 강조 표시된 버전을 생성하고 결과를 표준 출력에 기록합니다. 이 모든 프로세스는 ffbe95d20f3893062224282accb13e8f [...] 1cd55414ff5abdfea5dd958e7e547fddHTML 태그 블록을 생성하며 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 파일의 변수 값을 설정합니다. 구문은 다음과 같습니다.

-d 구성_디렉티브[=값]

예:

# 값 부분을 생략하면 주어진 구성 지시문이 "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 코드의 구문을 검사하는 편리한 방법을 제공합니다. 성공하면 No 구문 오류가 2334ac29606bf8a170583e4f7533b1f4 문자열에서 감지되어 표준 출력에 기록되고 셸은 0을 반환합니다. 실패하면 Errors parsing 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의 시작 및 끝 식별자(33f5f4285f0d6990215a2363bd102eef)를 추가하는 데 가 필요하지 않습니다. 그렇지 않으면 구문 분석 오류가 발생합니다.


참고: PHP 형식을 사용할 때는 쉘 환경에서 수행되는 명령줄 매개변수 대체와의 충돌을 피하기 위해 특별한 주의를 기울여야 합니다.

구문 구문 분석 오류를 보여주는 예

$ php -r "$foo = get_define_constants();" 명령줄 코드(1): 구문 분석 오류 - 구문 분석 오류, 예기치 않은 '='

여기서 문제는 큰따옴표 "를 사용하더라도 sh/bash가 여전히 매개변수 대체를 구현한다는 것입니다. $foo가 정의되지 않았기 때문에, 교체 후 해당 위치는 null 문자가 되므로 런타임 시 PHP에서 실제로 읽은 코드는 다음과 같습니다.

$ php -r " = get_define_constants();"

올바른 방법은 작은따옴표를 사용하는 것입니다 ' . 작은따옴표로 묶인 문자열의 변수는 sh/bash에 의해 원래 값으로 복원되지 않습니다.

$ php -r '$foo = get_define_constants();' 배열(370) { ["E_ERROR"]=> 정수(1) ["E_WARNING"]=> 정수(2) ["E_PARSE"]=> 정수(4) ["E_NOTICE"]=> 정수(8) ["E_CORE_ERROR"]=> [...]

sh/bash가 아닌 다른 쉘을 사용하는 경우 다른 문제가 발생할 수 있습니다. 발견한 버그를 보고하거나 phpdoc@lists.php.net으로 이메일을 보내주세요.

쉘의 환경 변수를 말에 도입하거나 백슬래시를 사용하여 문자를 이스케이프 처리할 때 다양한 문제에 직면할 수도 있으니 사용할 때 주의하세요!



참고: -rCLISAPI에서 유효하고 CGISAPI에서는 유효하지 않습니다.


-h 이 매개변수를 사용하면 명령줄 매개변수의 전체 목록과 이러한 매개변수의 기능에 대한 간단한 설명을 얻을 수 있습니다.


PHP의 명령줄 모드를 사용하면 PHP 스크립트를 웹 서버와 완전히 독립적으로 실행할 수 있습니다. Unix 시스템을 사용하는 경우 PHP 스크립트 시작 부분에 특수 코드 줄을 추가하여 실행되도록 해야 시스템이 스크립트를 실행하는 데 사용할 프로그램을 알 수 있습니다. Windows 플랫폼에서는 php.exe.php 파일의 두 번 클릭 속성을 연결하거나 배치 파일을 작성하여 PHP를 사용하여 스크립트를 실행할 수 있습니다. Unix 시스템에 추가된 첫 번째 코드 줄은 Windows에서 스크립트 실행에 영향을 주지 않으므로 이 방법을 사용하여 크로스 플랫폼 스크립트를 작성할 수도 있습니다. 다음은 간단한 PHP 명령줄 프로그램의 예입니다.


예 23-1. 명령줄에서 PHP 스크립트(script.php) 실행

#!/usr/bin/phpe159d9e0592f3f2c28e1979a7d751056이것은 하나의 옵션이 있는 명령줄 PHP 스크립트입니다. : e2d7428daea013db3450b097f583aa95은 --help, -h 또는 -? 옵션을 사용하여 출력할 수 있습니다. , 이 도움을 받을 수 있습니다.1368379bf0e06ed88222aa51004d0324

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

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

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



@c:phpcliphp.exe script.php %1 %2 %3 %4


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

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