<span style="font-size: 14px;">Usage: php [options] [-f] <file> [args...]<br> php [options] -r <code> [args...]<br> php [options] [-- args...]<br> -s Display colour syntax highlighted source.<br> -w Display source with stripped comments and whitespace.<br> -f <file> Parse <file>.<br> -v Version number<br> -c <path>|<file> 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 <file> Load Zend extension <file>.<br> -l Syntax check only (lint)<br> -m Show compiled in modules<br> -i PHP information<br> -r <code> Run PHP <code> without using script tags <?..?><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 환경에서는 사용해 보세요. 작은따옴표를 사용하여 완료합니다.
PHP가 지정된 파일을 실행하도록 합니다.
<span style="font-size: 14px;">php my_script.php <br/>php -f "my_script.php"<br/></span> 로그인 후 복사 |
위의 두 방법 모두(-f 매개변수 유무에 관계없이) 주어진 my_script.php 파일을 실행할 수 있습니다. 실행할 파일을 선택할 수 있습니다. 지정하는 PHP 스크립트에는 .php 확장자가 없어도 됩니다.
명령줄에서 직접 PHP 코드를 실행하세요.
<span style="font-size: 14px;">php -r "print_r(get_defined_constants());"<br/></span> 로그인 후 복사 |
이 방법을 사용할 때 쉘 변수 대체와 따옴표 사용에 주의하시기 바랍니다.
참고: 위의 예를 주의 깊게 읽어보세요. 코드를 실행할 때 시작 및 끝 표시가 없습니다! -r 매개변수를 사용하면 이러한 표시가 필요하지 않으며 구문 오류가 발생합니다.
표준 입력(stdin)을 통해 실행해야 하는 PHP 코드를 제공하세요.
위 사용법은 매우 강력한 기능을 제공하므로 다음 예와 같이 PHP 코드를 동적으로 생성하고 명령줄을 통해 이러한 코드를 실행할 수 있습니다. 위의 세 가지 코드 실행 방법은 동시에 사용할 수 없습니다.
$ some_application | some_filter | php | sort -u >final_output.txt
除此之外,我们还有另一个方法将 PHP 用于外壳脚本。您可以在写一个脚本,并在第一行以 #!/usr/bin/php 开头,在其后加上以 PHP 开始和结尾标记符包含的正常的 PHP 代码,然后为该文件设置正确的运行属性。该方法可以使得该文件能够像外壳脚本或 PERL 脚本一样被直接执行。
#!/usr/bin/php<br/><br/> 로그인 후 복사 로그인 후 복사 |
假设改文件名为 test 并被放置在当前目录下,我们可以做如下操作:
$ 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/> 로그인 후 복사 |
보시다시피 -로 시작하는 매개변수를 스크립트에 전달해도 스크립트는 여전히 정상적으로 실행됩니다.
표 23-3. 명령줄 옵션
옵션 이름 | 설명 |
---|---|
-s | 구문 강조 색상 소스와 함께 표시됨 파일. 이 매개변수는 내장 메커니즘을 사용하여 파일을 구문 분석하고 HTML 강조 버전을 생성한 후 결과를 표준 출력에 기록합니다. 이 모든 프로세스는
|
-w | 은 주석과 공백이 제거된 소스 코드를 보여줍니다.
|
-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 코드의 구문을 검사하는 편리한 방법을 제공합니다. 성공하면 이 매개변수는 치명적인 오류(예: 정의되지 않은 함수)를 확인할 수 없습니다. 치명적인 오류를 감지하려면 -f 매개변수를 사용하세요.
|
-m | 이 매개변수를 사용하면 PHP는 내장 및 로드된 PHP와 Zend 모듈을 인쇄합니다: $ php -m [PHP 모듈] xml 토크나이저 기준 세션 포식스 pcre 초과 적재 mysql mbstring ctype [Zend 모듈] |
-i | 이 명령줄 매개변수는 phpinfo() 함수를 호출하고 결과를 인쇄합니다. PHP가 제대로 작동하지 않으면 PHP를 실행하는 것이 좋습니다 -i 정보 테이블 앞이나 해당 위치에 오류 메시지 출력이 있는지 확인하는 명령입니다. 출력 내용이 HTML 형식이므로 출력 정보가 더 크다는 점에 유의하시기 바랍니다. |
-r | 명령줄에서 PHP 코드를 실행하려면 이 매개변수를 사용하세요. PHP 시작 및 끝 식별자()를 추가할 필요가 없습니다. 그렇지 않으면 구문 분석 오류가 발생합니다.
|
-h | 使用该参数,您可以得到完整的命令行参数的列表及这些参数作用的简单描述。 |
PHP 的命令行模式能使得 PHP 脚本能完全独立于 WEB 服务器单独运行。如果您使用 Unix 系统,您需要在您的 PHP 脚本的最前面加上一行特殊的代码,使得它能够被执行,这样系统就能知道用什么样的程序要运行该脚本。在 Windows 平台下您可以将 php.exe 和 .php 文件的双击属性相关联,您也可以编写一个批处理文件来用 PHP 执行脚本。为 Unix 系统增加的第一行代码不会影响该脚本在 Windows
下的运行,因此您也可以用该方法编写跨平台的脚本程序。以下是一个简单的PHP 命令行程序的范例。
例子 23-1. 试图以命令行方式运行的 PHP 脚本(script.php) #!/usr/bin/phpThis is a command line PHP script with one option. Usage: |
위 스크립트에서는 첫 번째 특수 코드 줄을 사용하여 파일이 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!