이 글에서는 주로 PHP로 개발된 아카이브 형식 phar 파일의 개념과 사용법을 소개하고, 아카이브 형식 phar 파일의 생성, 사용, 압축 풀기, 복원 및 추출을 예제와 기타 개념 및 작업 구현 방법을 통해 자세히 분석합니다. 다음
본 글의 예시에서는 PHP 개발 시 아카이브 형식 phar 파일의 개념과 사용법을 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.
PHP 응용 프로그램은 종종 여러 파일로 구성됩니다. 배포하고 실행하기 위해 하나의 파일에 집중할 수 있으면 매우 편리합니다. 이를 달성하기 위해 PHP는 phar 문서 파일 형식을 사용합니다. 이 개념은 Java의 jar에서 파생되었지만 주로 웹 환경을 위해 설계되었습니다. JAR 아카이브와 다른 PHP. 좋은 점은 Phar 아카이브를 PHP 자체에서 처리할 수 있으므로 이를 생성하거나 사용하기 위해 추가 도구를 사용할 필요가 없으며 PHP 스크립트를 사용하여 생성하거나 추출하기만 하면 됩니다. phar는 PHP와 Archive의 합성어로 PHP 아카이브 파일을 뜻한다고 볼 수 있습니다.
phar의 공식 웹사이트 문서는 http://php.net/manual/zh/book.phar.php를 참조하세요. 이 문서는 공식 웹사이트 문서를 보완하는 것으로 간주될 수 있습니다.
Phar 아카이브 파일은 다음과 같습니다. 세 가지 형식: tar 아카이브, zip 아카이브, phar 아카이브, 처음 두 가지 유형의 실행에서는 Phar 확장 지원을 설치해야 하며 여기서는 주로 phar 아카이브 형식에 대해 설명합니다.
phar 형식 아카이브 파일은 직접 실행할 수 있습니다. 생성은 Phar 확장에 의존하며 직접 작성한 PHP 스크립트로 생성됩니다.
Phar 확장은 PHP의 새로운 개념이 아니며 php5.3에서 PHP에 내장되었으며 원래 PHP로 작성되어 PHP_Archive라는 이름으로 명명된 후 2005년에 PEAR 라이브러리에 추가되었습니다. 이 문제에 대한 순수 PHP 솔루션은 실제로 매우 느리기 때문에 2007년에 순수 C 언어 확장으로 다시 작성되었으며 SPL의 ArrayAccess 개체를 사용하여 Phar 아카이브를 탐색하는 지원이 추가되었습니다. 그 이후로 Phar 아카이브의 성능을 개선하기 위한 많은 작업이 이루어졌습니다.
Phar 확장은 PHP 스트림 래퍼에 따라 달라집니다. 이에 대해서는 이전 기사 PHP 스트림, 래퍼 래퍼 개념 및 사용 예를 참조하세요.
많은 PHP 애플리케이션이 phar 형식으로 배포되고 실행됩니다. 작곡가, 단위 테스트: phpunit, 생성, 실행, 추출 및 복원 방법을 살펴보겠습니다.
phar 파일 생성:
먼저 php.ini에서 phar.readonly 옵션을 수정하고 앞의 세미콜론을 제거한 후 값을 off로 변경합니다. 보안상의 이유로 이 옵션은 기본적으로 켜져 있습니다. php.ini에서 비활성화된 경우(값이 0 또는 꺼짐) 사용자 스크립트에서 활성화하거나 비활성화할 수 있습니다. php.ini에서 활성화된 경우 사용자 스크립트를 비활성화할 수 없으므로 예제를 표시하려면 여기에서 off로 설정하세요.
프로젝트를 서버 루트 디렉터리에 프로젝트로 생성해 보겠습니다. 디렉터리의 구조는 다음과 같습니다.
file -yunek.js -yunke.css lib -lib_a.php template -msg.html index.php Lib.php
파일 폴더에는 두 개의 빈 js 및 css 파일이 있습니다. 다양한 파일 형식을 포함할 수 있습니다.
lib_a.php 내용은 다음과 같습니다.
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/10 * Time: 9:23 */ function show(){ echo "l am show()"; }
msg.html 내용은 다음과 같습니다.
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>phar</title> </head> <body> <?=$str; ?> </body> </html>
index.php 내용은 다음과 같습니다.
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/10 * Time: 9:17 */ require "lib/lib_a.php"; show(); $str = isset($_GET["str"]) ? $_GET["str"] : "hello world"; include "template/msg.html";
Lib .php 내용은 다음과 같습니다.
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/10 * Time: 9:20 */ function yunke() { echo "l am yunke()"; }
프로젝트 파일이 준비되었습니다. 이제 프로젝트 폴더와 동일한 디렉터리에 yunkeBuild.php를 생성하여 phar 형식 파일을 생성합니다.
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/10 * Time: 9:36 */ //产生一个yunke.phar文件 $phar = new Phar('yunke.phar', 0, 'yunke.phar'); // 添加project里面的所有文件到yunke.phar归档文件 $phar->buildFromDirectory(dirname(__FILE__) . '/project'); //设置执行时的入口文件,第一个用于命令行,第二个用于浏览器访问,这里都设置为index.php $phar->setDefaultStub('index.php', 'index.php');
그런 다음 브라우저에서 이 yunkeBuild.php 파일에 액세스하면 yunke.phar 파일이 생성됩니다. 이때 서버 루트 디렉터리 구조는 다음과 같습니다.
project yunkeBuild.php yunke.phar
이것은 phar 아카이브 파일을 생성하는 가장 간단한 프로세스입니다. 자세한 내용은 공식 웹사이트를 참조하세요. 프로젝트에 단일 실행 항목이 없으면 phar 아카이브 파일을 사용하는 것이 적합하지 않습니다.
phar 아카이브 파일 사용:
위에서 생성한 phar 파일을 사용하는 방법을 보여주기 위해 서버 루트 디렉터리에 index.php 파일을 생성하며 내용은 다음과 같습니다.
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/8 * Time: 9:33 */ require "yunke.phar"; require "phar://yunke.phar/Lib.php"; yunke();
있는 경우 는 index.php 파일의 첫 번째 줄일 뿐이고, 아카이브 파일을 사용하지 않을 때와 정확히 동일하게 다음 코드를 추가합니다:
require "project/index.php";
두 번째 줄이 없으면 세 번째 줄에 yunke() 정의되지 않았다는 메시지가 표시되어 phar 파일을 요구할 때 해당 파일을 모두 가져오는 것이 아니라 항목 실행 파일만 가져오는 것을 알 수 있습니다. 그러나 실제 프로젝트에서는 다른 파일을 가져오는 경우가 많습니다. 이 항목 파일에서 사용해야 합니다. 이 경우 항목 실행 파일은 project/index.php
phar 파일 추출 및 복원:
우리는 때때로 phar에 포함된 파일의 소스 코드가 궁금할 때가 있습니다. 이때 phar 파일을 복원해야 합니다. 그냥 살펴보려면 phpstorm 10과 같은 일부 IDE 도구를 사용하여 수정해야 하는 경우에는 압축을 풀어야 합니다. 데모에서는 작곡가.phar을 다운로드하여 서버 디렉터리에 넣고 다음 내용으로 루트 디렉터리에 get.php 파일을 만듭니다.
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/9 * Time: 19:02 */ $phar = new Phar('composer.phar'); $phar->extractTo('composer'); //提取一份原项目文件 $phar->convertToData(Phar::ZIP); //另外再提取一份,和上行二选一即可
用浏览器访问这个文件,即可提取出来,以上列子展示了两种提取方式:第二行将建立一个composer目录,并将提取出来的内容放入,第三行将产生一个composer.zip文件,解压即可得到提取还原的项目文件。
补充:
1、在部署phar文件到生产服务器时需要调整服务器的配置,避免当访问时浏览器直接下载phar文件
2、可以为归档设置别名,别名保存在归档文件中永久保存,它可以用一个简短的名字引用归档,而不管归档文件在文件系统中存储在那里,设置别名:
$phar = new Phar('lib/yunke.phar', 0); $phar->setAlias ( "yun.phar");
设置别名后可以如下使用:
<?php require "lib/yunke.phar"; require "phar://yun.phar/Lib.php"; //使用别名访问归档文件 require "phar://lib/yunke.phar/Lib.php"; //当然仍然可以使用这样的方式去引用
如果在制作phar文件时没有指定别名,也可以在存根文件里面使用Phar::mapPhar('yunke.phar');
指定
3、归档文件中有一个存根文件,其实就是一段php执行代码,在制作归档时可以设置,直接执行归档文件时,其实就是执行它,所以它是启动文件;在脚本中包含归档文件时就像包含普通php文件一样包含它并运行,但直接以phar://的方式包含归档中某一个文件时不会执行存根代码, 往往在存根文件里面require包含要运行的其他文件,对存根文件的限制仅为以__HALT_COMPILER();
结束,默认的存根设计是为在没有phar扩展时能够运行,它提取phar文件内容到一个临时目录再执行,不过从php5.3开始该扩展默认内置启用了
4、制作的phar文件不能被改动,因此配置文件之类的文件需要另外放置在归档文件外面
5、mapPhar函数:这个函数只应该在stub存根代码中调用,在没有设置归档别名的时候可以用来设置别名,打开一个引用映射到phar流
相关推荐:
위 내용은 PHP 개발 아카이브 형식 phar 파일 개념 및 사용법(예)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!