머리말
라우팅 구성을 소개하는 Zend Framework2 "ZF2 Multi-level Tree Routing Route Configuration 예제"에 대한 기술 기사를 읽었습니다. 저는 이것이 매우 흥미롭다고 생각합니다.
/user는 사용자 목록 페이지에 해당합니다.
/user/:user_id는 사용자의 개인 홈페이지에 해당합니다. AlloVince 사용자의 개인 홈페이지
/user/:user_id/blog/는 사용자의 블로그 목록 페이지에 해당합니다. 예를 들어 /user/AlloVince/blog는 AlloVince
/user/:user_id/blog/가 작성한 블로그를 나열합니다. :blog_id 사용자에 해당하는 기사 블로그 기사
구성표는 원문에서 인용되었습니다:
'router' => array( 'routes' => array( 'user' => array( 'type' => 'Segment', 'options' => array( 'route' => '/user[/]', 'defaults' => array( 'controller' => 'UserController', 'action' => 'index', ), ), 'may_terminate' => true, 'child_routes' => array( 'profile' => array( 'type' => 'Segment', 'options' => array( 'route' => '[:id][/]', 'constraints' => array( 'id' => '[a-zA-Z0-9_-]+' ), 'defaults' => array( 'action' => 'get' ), ), 'may_terminate' => true, 'child_routes' => array( 'blog' => array( 'type' => 'Segment', 'options' => array( 'route' => 'blog[/]', 'constraints' => array( ), 'defaults' => array( 'action' => 'blog' ) ), 'may_terminate' => true, 'child_routes' => array( 'post' => array( 'type' => 'Segment', 'options' => array( 'route' => '[:post_id][/]', 'constraints' => array( 'post_id' => '[a-zA-Z0-9_-]+' ), 'defaults' => array( 'action' => 'post' ) ), 'may_terminate' => true, ), ), ), ), //profile child_routes end ), //profile end ), //user child_routes end ), //user end ), ),
이 기사를 읽은 후 이 라우팅 요구 사항을 구현하는 데 사용한 PHP 프레임워크를 사용하세요.
ThinkPHP
새 ThinkPHP 프로젝트 만들기:
코드는 다음과 같습니다.
composer create-project topthink/thinkphp tp --prefer-dist
명령줄에 설치 내용이 표시됩니다.
topthink/thinkphp (3.2.2) 설치
ThinkPHP 공식 웹사이트의 최신 안정 버전은 3.2.3인 것으로 확인됩니다.
Packagist 공식 홈페이지에 가서 확인해 보니 라이브러리에 있는 안정 버전이 실제로 3.2.2였습니다.
3.2.3을 사용해야 합니다. 나는 왜 이것에 이렇게 집착하는 걸까? 이유:
3.2의 라우팅 기능은 모듈에 대해 설정되어 있으므로 URL의 모듈 이름을 라우팅할 수 없으며 라우팅 정의는 일반적으로 모듈 구성 파일에 배치됩니다. 버전 3.2.3에는 전역 경로 정의 지원이 추가되었으며 프로젝트의 공개 구성 파일에서 경로를 정의할 수 있습니다.
즉, 라우팅 재작성 부분은 컨트롤러와 액션 부분인데, Moudle은 여전히 존재합니다.
home/user가 아닌 /user를 원합니다. (ThinkPHP의 기본 모듈은 Home, 'DEFAULT_MODULE' => 'Home'이며 수정 가능)
물론 이 문제는 .htaccess 파일을 수정하여 해결할 수도 있습니다. 하지만 3.2.3을 설치하기로 결정했습니다.
ThinkPHP 공식 홈페이지에서 최신 패키지를 다운로드하고 압축을 풀어주세요.
브라우저를 사용하여 프로젝트 항목 파일에 액세스하고 ThinkPHP가 자동으로 기본 애플리케이션 모듈 홈을 생성하도록 합니다.
공용 구성 파일 tpApplicationCommonConfconfig.php를 수정합니다.
<?php return array( // 开启路由 'URL_ROUTER_ON' => true, // URL访问模式,可选参数0、1、2、3,代表以下四种模式: // 0 (普通模式); 1 (PATHINFO 模式); 2 (REWRITE 模式); 3 (兼容模式) 默认为PATHINFO 模式 'URL_MODEL' => 2, // URL伪静态后缀设置,为空表示可以支持所有的静态后缀 // 使用U函数生成URL时会不带后缀 'URL_HTML_SUFFIX' => '', // URL变量绑定到Action方法参数,默认为true 'URL_PARAMS_BIND' => true, // URL变量绑定的类型 0 按变量名绑定 1 按变量顺序绑定,默认为0 'URL_PARAMS_BIND_TYPE' => 0, // 路由配置 'URL_ROUTE_RULES' => array( '/^url$/' => 'Home/User/url', '/^user$/' => 'Home/User/index', '/^user\/([a-zA-Z0-9_-]+)$/' => 'Home/User/show?name=:1', '/^user\/([a-zA-Z0-9_-]+)\/blog$/' => 'Home/Blog/index?name=:1', '/^user\/([a-zA-Z0-9_-]+)\/blog\/([0-9]+)$/' => 'Home/Blog/show?name=:1&blog_id=:2', ), ); ?>
tpApplicationHomeControllerUserController 파일을 생성합니다. class.php:
<?php namespace Home\Controller; use Think\Controller; class UserController extends Controller { public function url() { $name = 'jing'; $blogId = 1; $urls = array( U('/user'), U("/user/{$name}"), U("/user/{$name}/blog"), U("/user/{$name}/blog/{$blogId}"), ); foreach ($urls as $url) { echo "<a href=\"{$url}\">{$url}<a/><br />\n"; } } public function index() { echo '我是用户列表^_^'; } public function show($name) { echo "欢迎你,{$name}"; } } ?>
tpApplicationHomeControllerBlogController.class.php 파일 생성:
<?php namespace Home\Controller; use Think\Controller; class BlogController extends Controller { public function index($name) { echo "这是{$name}的博客列表"; } public function show($blog_id, $name) { echo "{$name}的这篇博客的id为{$blog_id}"; } } ?>
출력:
코드는 다음과 같습니다.
<a href="/tp/user">/tp/user<a/><br /> <a href="/tp/user/jing">/tp/user/jing<a/><br /> <a href="/tp/user/jing/blog">/tp/user/jing/blog<a/><br /> <a href="/tp/user/jing/blog/1">/tp/user/jing/blog/1<a/><br />
위 4개의 링크를 방문하여 차례로 돌아옵니다.
나는 사용자 목록입니다^_^
환영합니다, jing
This is jing
jing의 블로그 목록의 ID는 1입니다.
아래의 다른 프레임워크에서도 위 내용이 출력됩니다.
Zend Framework 2
ZF2 스켈레톤 프로그램을 사용하여 ZF2 프로젝트 생성:
composer create-project --stability="dev" zendframework/ Skeleton -application zf2
기본 모듈 애플리케이션의 구성 파일 zf2moduleApplicationconfigmodule.config.php를 수정합니다:
<?php /** * Zend Framework (http://framework.zend.com/) * * @link http://github.com/zendframework/ZendSkeletonApplication for the canonical source repository * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com) * @license http://framework.zend.com/license/new-bsd New BSD License */ return array( 'router' => array( 'routes' => array( 'home' => array( 'type' => 'Zend\Mvc\Router\Http\Literal', 'options' => array( 'route' => '/url', 'defaults' => array( 'controller' => 'Application\Controller\User', 'action' => 'url', ), ), ), // The following is a route to simplify getting started creating // new controllers and actions without needing to create a new // module. Simply drop new controllers in, and you can access them // using the path /application/:controller/:action 'application' => array( 'type' => 'Literal', 'options' => array( 'route' => '/application', 'defaults' => array( '__NAMESPACE__' => 'Application\Controller', 'controller' => 'Index', 'action' => 'index', ), ), 'may_terminate' => true, 'child_routes' => array( 'default' => array( 'type' => 'Segment', 'options' => array( 'route' => '/[:controller[/:action]]', 'constraints' => array( 'controller' => '[a-zA-Z][a-zA-Z0-9_-]*', 'action' => '[a-zA-Z][a-zA-Z0-9_-]*', ), 'defaults' => array( ), ), ), ), ), 'user_list' => array( 'type' => 'Segment', 'options' => array( 'route' => '/user[/]', 'defaults' => array( '__NAMESPACE__' => 'Application\Controller', 'controller' => 'User', 'action' => 'index', ), ), 'may_terminate' => true, 'child_routes' => array( 'user' => array( 'type' => 'Segment', 'options' => array( 'route' => '[:name][/]', 'constraints' => array( 'name' => '[a-zA-Z0-9_-]+', ), 'defaults' => array( 'action' => 'show', ), ), 'may_terminate' => true, 'child_routes' => array( 'blog_list' => array( 'type' => 'Segment', 'options' => array( 'route' => 'blog[/]', 'constraints' => array( ), 'defaults' => array( 'controller' => 'Blog', 'action' => 'index', ) ), 'may_terminate' => true, 'child_routes' => array( 'blog' => array( 'type' => 'Segment', 'options' => array( 'route' => '[:blog_id]', 'constraints' => array( 'blog_id' => '[0-9]+', ), 'defaults' => array( 'action' => 'show', ) ), 'may_terminate' => true, ), ), ), ), ), ), ), ), ), 'service_manager' => array( 'abstract_factories' => array( 'Zend\Cache\Service\StorageCacheAbstractServiceFactory', 'Zend\Log\LoggerAbstractServiceFactory', ), 'aliases' => array( 'translator' => 'MvcTranslator', ), ), 'translator' => array( 'locale' => 'en_US', 'translation_file_patterns' => array( array( 'type' => 'gettext', 'base_dir' => __DIR__ . '/../language', 'pattern' => '%s.mo', ), ), ), 'controllers' => array( 'invokables' => array( 'Application\Controller\Index' => 'Application\Controller\IndexController', 'Application\Controller\User' => 'Application\Controller\UserController', 'Application\Controller\Blog' => 'Application\Controller\BlogController', ), ), 'view_manager' => array( 'display_not_found_reason' => true, 'display_exceptions' => true, 'doctype' => 'HTML5', 'not_found_template' => 'error/404', 'exception_template' => 'error/index', 'template_map' => array( 'layout/layout' => __DIR__ . '/../view/layout/layout.phtml', 'application/index/index' => __DIR__ . '/../view/application/index/index.phtml', 'error/404' => __DIR__ . '/../view/error/404.phtml', 'error/index' => __DIR__ . '/../view/error/index.phtml', ), 'template_path_stack' => array( __DIR__ . '/../view', ), ), // Placeholder for console routes 'console' => array( 'router' => array( 'routes' => array( ), ), ), ); ?>
스켈레톤 프로그램과 함께 제공되는 파일입니다. 라우터 부분과 컨트롤러 부분만 수정했습니다. 이렇게 긴 문서를 작성하는 것은 나에게 너무 어려울 것입니다. ZF가 공식적으로 스켈레톤 프로그램을 발표한 이유이기도 하다.
zf2moduleApplicationsrcApplicationControllerUserController.php 파일 생성:
<?php namespace Application\Controller; use Zend\Mvc\Controller\AbstractActionController; use Zend\View\Model\ViewModel; class UserController extends AbstractActionController { public function urlAction() { $name = 'jing'; $blogId = 1; $urls = array( $this->url()->fromRoute('user_list'), $this->url()->fromRoute('user_list/user', array('name' => $name)), $this->url()->fromRoute('user_list/user/blog_list', array('name' => $name)), $this->url()->fromRoute('user_list/user/blog_list/blog', array('name' => $name, 'blog_id' => $blogId)), ); $view = new ViewModel(compact('urls')); $view->setTerminal(true); return $view; } public function indexAction() { $view = new ViewModel(); // 禁用布局模板 $view->setTerminal(true); return $view; } public function showAction() { $username = $this->params()->fromRoute('name'); $view = new ViewModel(compact('username')); $view->setTerminal(true); return $view; } } ?>
zf2moduleApplicationsrcApplicationControllerBlogCon troller.php 파일 생성:
<?php namespace Application\Controller; use Zend\Mvc\Controller\AbstractActionController; use Zend\View\Model\ViewModel; class BlogController extends AbstractActionController { public function indexAction() { $username = $this->params()->fromRoute('name'); $view = new ViewModel(compact('username')); $view->setTerminal(true); return $view; } public function showAction() { $username = $this->params()->fromRoute('name'); $blogId = $this->params()->fromRoute('blog_id'); $view = new ViewModel(compact('username', 'blogId')); $view->setTerminal(true); return $view; } } ?>
zf2는 Action 매개변수 바인딩을 지원하지 않습니다. ThinkPHP는 바인딩뿐만 아니라 2가지 바인딩 방법도 지원합니다. 변수 이름으로 바인딩하고 변수 순서로 바인딩합니다.
exit()를 제외하고 zf2의 작업은 뷰로 돌아가야 합니다. 보기를 비활성화하는 방법을 알고 계시다면 알려주세요.
zf2moduleApplicationviewapplicationuserurl.phtml 파일 생성:
<?php foreach ($urls as $url): ?> <a href="<?php echo $url;?>"><?php echo $url;?><a/><br /> <?php endforeach; ?>
zf2moduleApplicationviewapplicationuserindex.phtml 파일 생성:
나는 사용자 목록입니다^_^
파일 생성 zf2moduleApplicationviewapplicationusershow.phtml:
환영합니다.
파일 생성 zf2moduleApplicationviewapplicationblogindex.phtml:
이것은 블로그 목록
zf2moduleApplicationviewapplicationblogshow.phtml 파일 만들기:
<?php echo $username; ?>的这篇博客的id为<?php echo $blogId; ?>
Yaf
Yaf 설치
코드 생성 도구를 사용하여 Yaf 프로젝트 생성
시작 파일 yafapplicationBootstrap.php를 수정하고 그 안의 _initRoute 메소드를 수정합니다:
$router = Yaf_Dispatcher::getInstance()->getRouter(); $route0 = new Yaf_Route_Rewrite('url', array( 'controller' => 'User', 'action' => 'url', ), array() ); $route1 = new Yaf_Route_Rewrite('user', array( 'controller' => 'User', 'action' => 'index', ), array() ); $route2 = new Yaf_Route_Regex('#user/([a-zA-Z0-9_-]+)#', array( 'controller' => 'User', 'action' => 'show', ), array(1 => 'name',) ); $route3 = new Yaf_Route_Regex('#user/([a-zA-Z0-9_-]+)/blog#', array( 'controller' => 'Blog', 'action' => 'index', ), array(1 => 'name',) ); $route4 = new Yaf_Route_Regex('#user/([a-zA-Z0-9_-]+)/blog/([0-9]+)#', array( 'controller' => 'Blog', 'action' => 'show', ), array(1 => 'name', 2 => 'blogId',) ); $router->addRoute('url', $route0); $router->addRoute('user_list', $route1); $router->addRoute('user', $route2); $router->addRoute("blog_list", $route3); $router->addRoute("blog", $route4);
Yaf에는 라우팅 기능이 있지만 경로명을 기준으로 URL을 생성하는 방법은 없습니다. 그래서 URL을 연결하기 위한 프로젝트 이름을 정의했습니다.
구성 파일에 구성 항목 yafconfapplication.ini를 추가합니다.
project.name = 'yaf'
yafapplicationcontrollersUser.php 파일을 생성합니다.
<?php class UserController extends Yaf_Controller_Abstract { public function urlAction() { $name = 'jing'; $blogId = 1; $app = Yaf_Application::app(); $projectName = $app->getConfig()->project->name; $urls = array( "/{$projectName}/user", "/{$projectName}/user/{$name}", "/{$projectName}/user/{$name}/blog", "/{$projectName}/user/{$name}/blog/{$blogId}", ); foreach ($urls as $url) { echo "<a href=\"{$url}\">{$url}<a/><br />\n"; } return false; } public function indexAction() { echo '我是用户列表^_^'; // 禁用视图模板 return false; } public function showAction($name) { echo "欢迎你,{$name}"; return false; } }
Create yafapplicationcontrollersBlog .php 파일:
코드는 다음과 같습니다.
<?php class BlogController extends Yaf_Controller_Abstract { public function indexAction($name) { echo "这是{$name}的博客列表"; return false; } public function showAction($blogId, $name) { echo "{$name}的这篇博客的id为{$blogId}"; return false; }
Yaf의 Action은 변수 이름으로 바인딩되는 매개변수 바인딩을 지원합니다. $name 및 $blogId는 매개변수 순서에 관계없이 경로에 구성된 이름과 동일해야 합니다.
Laravel
新建Laravel项目:
composer create-project laravel/laravel --prefer-dist
清除合并文件。在目录laravel\vendor\下有个文件compiled.php,这个文件是为了减少IO提高框架性能,将很多类文件合并到一个文件中而生存的。在开发环境下,应该删除该文件,否则修改了一些文件发现没有效果,其实是因为文件已经合并缓存了。
清除命令:
php artisan clear-compiled
在生产环境中应该开启,以提升性能:
php artisan optimize --force
修改路由文件laravel\app\Http\routes.php:
<?php Route::get('/url', array('uses' => 'UserController@getUrl')); Route::get('/user', array('uses' => 'UserController@getIndex')); Route::get('/user/{username}', array('uses' => 'UserController@getShow')); Route::get('/user/{username}/blog', array( 'as' => 'blog_list', 'uses' => 'BlogController@getIndex', )); Route::get('/user/{username}/blog/{blogId}', array( 'as' => 'blog', 'uses' => 'BlogController@getShow', ))->where(array('blogId' => '[0-9]+'));
查看路由定义情况:
代码如下:
php artisan route:list
输出:
代码如下:
+--------+----------+-------------------------------+-----------+----------------------------------------------+------------+ | Domain | Method | URI | Name | Action | Middleware | +--------+----------+-------------------------------+-----------+----------------------------------------------+------------+ | | GET|HEAD | url | | App\Http\Controllers\UserController@getUrl | | | | GET|HEAD | user | | App\Http\Controllers\UserController@getIndex | | | | GET|HEAD | user/{username} | | App\Http\Controllers\UserController@getShow | | | | GET|HEAD | user/{username}/blog | blog_list | App\Http\Controllers\BlogController@getIndex | | | | GET|HEAD | user/{username}/blog/{blogId} | blog | App\Http\Controllers\BlogController@getShow | | +--------+----------+-------------------------------+-----------+----------------------------------------------+------------+
定义路由变量全局模式,修改文件laravel\app\Providers\RouteServiceProvider.php中的boot方法:
代码如下:
public function boot(Router $router) { $router->pattern('username', '[a-zA-Z0-9_-]+'); parent::boot($router); }
创建UserController控制器:
代码如下:
php artisan make:controller UserController
Laravel帮我们在laravel\app\Http\Controllers目录下创建了文件UserController.php,文件中已经为我们写好一部分骨架代码。修改文件laravel\app\Http\Controllers\UserController.php:
代码如下:
<?php namespace App\Http\Controllers; use App\Http\Controllers\Controller; class UserController extends Controller { public function getUrl() { $name = 'jing'; $blogId = 1; $urls = array( url('/user'), action( 'UserController@getShow' , array($name)), route('blog_list', array($name)), route('blog', array($name, $blogId)), ); foreach ($urls as $url) { echo " {$url} \n"; } } public function getIndex() { echo '我是用户列表^_^'; } public function getShow($name) { echo "欢迎你,{$name}"; } }
创建BlogController控制器:
代码如下:
php artisan make:controller BlogController
修改文件laravel\app\Http\Controllers\BlogController.php:
代码如下:
<?php namespace App\Http\Controllers; use App\Http\Controllers\Controller; class BlogController extends Controller { public function getIndex($name) { echo "这是{$name}的博客列表"; } public function getShow($name, $blogId) { echo "{$name}的这篇博客的id为{$blogId}"; } }
Laravel的Action也支持参数绑定,是按变量顺序绑定的,和变量名无关。
后语
我是Laravel粉,但是我也没有想黑其他框架的意思,大家有兴趣也可以用自己熟悉的框架来实现这个小例子,写了记得@我,语言不限。
以上所述就是本文的全部内容了,希望大家能够喜欢。
请您花一点时间将文章分享给您的朋友或者留下评论。我们将会由衷感谢您的支持!
以上就是ThinkPHP、ZF2、Yaf、Laravel框架路由大比拼_php技巧的内容,更多相关内容请关注PHP中文网(www.php.cn)!

PHP와 Python은 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1.PHP는 간단한 구문과 높은 실행 효율로 웹 개발에 적합합니다. 2. Python은 간결한 구문 및 풍부한 라이브러리를 갖춘 데이터 과학 및 기계 학습에 적합합니다.

PHP는 죽지 않고 끊임없이 적응하고 진화합니다. 1) PHP는 1994 년부터 새로운 기술 트렌드에 적응하기 위해 여러 버전 반복을 겪었습니다. 2) 현재 전자 상거래, 컨텐츠 관리 시스템 및 기타 분야에서 널리 사용됩니다. 3) PHP8은 성능과 현대화를 개선하기 위해 JIT 컴파일러 및 기타 기능을 소개합니다. 4) Opcache를 사용하고 PSR-12 표준을 따라 성능 및 코드 품질을 최적화하십시오.

PHP의 미래는 새로운 기술 트렌드에 적응하고 혁신적인 기능을 도입함으로써 달성 될 것입니다. 1) 클라우드 컴퓨팅, 컨테이너화 및 마이크로 서비스 아키텍처에 적응, Docker 및 Kubernetes 지원; 2) 성능 및 데이터 처리 효율을 향상시키기 위해 JIT 컴파일러 및 열거 유형을 도입합니다. 3) 지속적으로 성능을 최적화하고 모범 사례를 홍보합니다.

PHP에서, 특성은 방법 재사용이 필요하지만 상속에 적합하지 않은 상황에 적합합니다. 1) 특성은 클래스에서 다중 상속의 복잡성을 피할 수 있도록 수많은 방법을 허용합니다. 2) 특성을 사용할 때는 대안과 키워드를 통해 해결할 수있는 방법 충돌에주의를 기울여야합니다. 3) 성능을 최적화하고 코드 유지 보수성을 향상시키기 위해 특성을 과도하게 사용해야하며 단일 책임을 유지해야합니다.

의존성 주입 컨테이너 (DIC)는 PHP 프로젝트에 사용하기위한 객체 종속성을 관리하고 제공하는 도구입니다. DIC의 주요 이점에는 다음이 포함됩니다. 1. 디커플링, 구성 요소 독립적 인 코드는 유지 관리 및 테스트가 쉽습니다. 2. 유연성, 의존성을 교체 또는 수정하기 쉽습니다. 3. 테스트 가능성, 단위 테스트를 위해 모의 객체를 주입하기에 편리합니다.

SplfixedArray는 PHP의 고정 크기 배열로, 고성능 및 메모리 사용이 필요한 시나리오에 적합합니다. 1) 동적 조정으로 인한 오버 헤드를 피하기 위해 생성 할 때 크기를 지정해야합니다. 2) C 언어 배열을 기반으로 메모리 및 빠른 액세스 속도를 직접 작동합니다. 3) 대규모 데이터 처리 및 메모리에 민감한 환경에 적합하지만 크기가 고정되어 있으므로주의해서 사용해야합니다.

PHP는 $ \ _ 파일 변수를 통해 파일 업로드를 처리합니다. 보안을 보장하는 방법에는 다음이 포함됩니다. 1. 오류 확인 확인, 2. 파일 유형 및 크기 확인, 3 파일 덮어 쓰기 방지, 4. 파일을 영구 저장소 위치로 이동하십시오.

JavaScript에서는 NullCoalescingOperator (??) 및 NullCoalescingAssignmentOperator (?? =)를 사용할 수 있습니다. 1. 2. ??= 변수를 오른쪽 피연산자의 값에 할당하지만 변수가 무효 또는 정의되지 않은 경우에만. 이 연산자는 코드 로직을 단순화하고 가독성과 성능을 향상시킵니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.
