This document provides instructions for deploying PDFlib products as PHP extensions on various platforms. It explains that precompiled PDFlib dynamic shared objects (DSOs) are available for many PHP versions and platforms. The document outlines the skill levels required for different installation and configuration tasks, and provides steps for testing the installation and deploying the PDFlib DSO, including copying the DSO file to the appropriate extension directory and restarting PHP. It also discusses considerations for using PDFlib in hosting environments.
This document provides instructions for deploying PDFlib products as PHP extensions on various platforms. It explains that precompiled PDFlib dynamic shared objects (DSOs) are available for many PHP versions and platforms. The document outlines the skill levels required for different installation and configuration tasks, and provides steps for testing the installation and deploying the PDFlib DSO, including copying the DSO file to the appropriate extension directory and restarting PHP. It also discusses considerations for using PDFlib in hosting environments.
with PHP Last change: December 19, 2013 Latest PDFlib version covered in this document: 9.0.2 Latest version of this document available at: www.pdflib.com/developer/technical-documentation Contact: PDFlib GmbH Franziska-Bilek-Weg 9 80339 Mnchen, Germany phone +49 89 452 33 84-0 support@pdflib.com www.pdflib.com 1 Scope of this Document This document explains various possibilities for successfully deploying PDFlib products as a PHP extension. The generic term PDFlib is used to designate one of the following distinct products: > The commercial PDFlib product > PDFlib+PDI, a commercial superset of PDFlib which also contains the PDF Import Library (PDI) > PDFlib Personalization Server (PPS), a superset of PDFlib+PDI with advanced Block filling features for personalizing PDF documents. Most of the PDFlib information applies to other PDFlib GmbH products analogously. Notes for the following products are included where applicable: > PDFlib TET (Text Extraction Toolkit) > PDFlib PLOP (Linearization, Optimization, Protection) and PLOP DS (Digital Signa- ture) > PDFlib pCOS (PDF Information Retrieval Tool) The methods for deploying any of these products as a PHP extension are the same in all cases. Multiple versions of these products cannot be deployed at the same time. Differ- ent products can coexist within one PHP installation, however. Note that the evaluation versions of commercial PDFlib products will be fully functional, but will display a demo stamp across all generated PDF pages unless a valid license key is applied. Other PDFlib GmbH products have other restrictions in evaluation mode (see documentation). This document applies to the following versions of PDFlib GmbH products: > PDFlib 9.0.2 > TET 4.2 > PLOP and PLOP DS 4.1 > pCOS 4.0 Where applicable, version-specific information is provided separately. 2 The PDFlib-in-PHP HowTo 2 Supported Platforms and PHP Versions Loadable PHP extension modules implemented as DSOs (dynamic shared objects, also called dynamic link library DLL) are the recommended method of using PDFlib with PHP. PHP supports dynamic loading of extensions from DSOs on the following plat- forms (only platforms supported by PDFlib GmbH are mentioned here): > Windows Server on x86 and Windows XP/Vista/7/8 on x86 > OS X and OS X Server 10.6 and above? > Linux on x86 and Intel 64 > Linux on zSeries > FreeBSD 7/8/9 on x86 > Oracle Solaris 10 on x86 and Sparc > HP-UX > AIX 32-bit; the PDFlib DSO for AIX can also be used on IBM i5/iSeries > IBM i5/iSeries (see Section 6.4, Installing and Using the PDFlib DSO on i5/iSeries) The distribution packages shipped by PDFlib GmbH contain DSOs for a number of PHP versions. These are grouped into several directories as follows (not all PHP versions are supported on all platforms, though): > bind/php/php-530 for PHP 5.3.0 and above > bind/php/php-540 for PHP 5.4.0 and above > bind/php/php-550 for PHP 5.5.0 and above Using commercial PDFlib packages with PHP on platforms with DSO support. PDFlib GmbH makes available packages with precompiled binary PDFlib DSOs for several plat- forms and PHP versions. If such a package is available for your combination of platform and PHP proceed with Section 6, Deploying the PDFlib DSO. Chapter 3: Required Skill Levels 3 3 Required Skill Levels Making PDFlib work with PHP requires various skill levels depending on your operating system platform. We will classify tasks according to the following skill sets: > A PHP Web programmer knows how to write code for PHP, but doesnt have experi- ence with other languages or general system administration tasks. The PHP pro- grammer usually has access to other people who are responsible for performing con- figuration tasks. > A sysadmin feels comfortable working with PEAR and other command-line tools, hap- pily edits php.ini and does not hesitate to restart the Web server (i.e. Apache or IIS) if required for installation or configuration purposes. Appropriate permissions (access rights) to do all this are also part of the sysadmin profile. > A C developer has access to a C development environment (header files, compiler, linker, associated system libraries) and can work with configure scripts and Make- files or corresponding IDE features. It may help to classify yourself according to these types of developers. The remainder of this document describes tasks which require at least sysadmin or C developer skills. PHP developers without additional knowledge or assistance will not be able to perform the required steps without assistance. 4 The PDFlib-in-PHP HowTo 4 Testing your Installation After you installed your PDFlib product extension for PHP using any of the methods discussed in this document you may want to test your installation in order to see whether everything works as expected. The PHP info page. You can test the success of your PDFlib product installation and configuration with the following mini PHP script: <?phpinfo()?> Check the output created by phpinfo( ) for one of the following: > If the output contains the line PDFlib GmbH Binary Version you are using a precompiled PDFlib DSO provided by PDFlib GmbH. > If you see the line PDFlib GmbH Version you are using your own PDFlib DSO or custom PHP with a statically linked PDFlib. The version number of the PECL module which has been used to build the PDFlib ex- tension will also be shown. > If you don't find any PDFlib section check your log files to determine the reason. The PDFlib product examples. The distribution package of your PDFlib product in- cludes two flavors of examples which you can use to test your installation. In the bind/ php directory you can find PDFlib programming examples. To use the examples proceed as follows: > Copy the PHP samples and data files to your htdocs directory: $ cp bind/php/*.php .../htdocs $ cp bind/data/* .../htdocs/data > point your browser to the URLs of the examples > enjoy the generated PDFs Chapter 5: PDFlib in Hosting Environments 5 5 PDFlib in Hosting Environments You are running a site at a Web hosting provider. In this case there are various consid- erations (we can ignore the case where a PDFlib extension for PHP is already installed since theres nothing more to do): > Some providers do not allow custom PHP extensions; in this case you are out of luck. > With some providers you can maintain your own copy of php.ini, while others dont allow this. If you cant edit php.ini and this file contains enable_dl=Off you are out of luck. You are a Web hosting provider. As a provider you should be aware of the following: > Although PDFlib Lite source code is freely available, and many Linux and PHP distri- butions contain PDFlib Lite, the PDFlib Lite license does not cover free use of PDFlib Lite on a Web hosters systems. > You can install commercial PDFlib DSOs even without obtaining a license. In this sit- uation you can install one of the precompiled PDFlib DSOs supplied by PDFlib GmbH without a license key (i.e. a demo stamp will be created). Those among your custom- ers who wish to commercially use it can obtain a commercial license to disable the demo stamp. In other words, you can offer PDFlib without the need for obtaining a li- cense for all of your servers. The recommended method is to install the PDFlib DSO in some globally accessible directory, and set the extension= line in php.ini appropri- ately. > Alternatively, if (like an increasing number of providers) you believe in PDFlib avail- ability as a competitive advantage, you can obtain a site license which covers all your servers and customers. Individual users will no longer be required to obtain a license on their own in this case. Please contact PDFlib GmbH if you are interested in more details. 6 The PDFlib-in-PHP HowTo 6 Deploying the PDFlib DSO Note In addition to the PDFlib product family, this section also applies to PDFlib TET, PDFlib PLOP, and PDFlib pCOS if you replace the string php_pdflib with php_tet, php_plop, or php_ pcos, respectively. Requirements: > Skill level: sysadmin > The PDFlib DSO, either built on your own or (preferably) from a binary package pro- vided by PDFlib GmbH at www.pdflib.com/download/pdflib-family/pdflib-9 > Working PHP binary This section applies to the prebuilt DSOs distributed by PDFlib GmbH, as well as to DSOs which you have built yourself. 6.1 Installing the PDFlib DSO on Windows The PDFlib DSOs for Windows (actually DLLs) have been tested with the binary PHP dis- tribution which is available from www.php.net. You will find PDFlib DSOs for various versions of PHP on Windows in the uncompressed package. The PDFlib DSO in the following directory has been built for a multithreaded version of PHP: bind/php/php-<version>/php_pdflib.dll We also offer Windows binaries of the PDFlib PHP binding which have been built with- out support for thread safety. These binaries are named as follows (ZTS refers to Zend Thread Safety, a threading abstraction layer): bind/php/php-<version>-nozts/php_pdflib.dll The PDFlib binding for PHP has been built for the Visual Studio 2008 (also called VS9) version. For the PHP installation process please follow the documentation of your PHP distri- bution and copy the PDFlib DSO to the directory which is specified in the extension_dir line in php.ini. Using PDFlib with Zend Server. In order to use PDFlib with Zend Server you must in- stall the DLL php_pdflib.dll from the php-<version>-nozts_VS9 directory. Copy this DLL to the extension directory and restart PHP. 6.2 Installing the PDFlib DSO on Unix The PDFlib DSOs for various Unix platforms are available for different versions of PHP. You will find PDFlib DSOs in the following location of the uncompressed package (ad- just the shared library suffix as necessary for your platform): bind/php/php-<version>/php_pdflib.so Copy the PDFlib DSO to the directory which is specified in the extension_dir line in php.ini. Chapter 6: Deploying the PDFlib DSO 7 The standard Unix versions of the PDFlib DSO have been built without multithread support. However, the binaries bind/php/php-<version>mt/php_pdflib.so which are available for some platforms are PDFlib DSOs for use with versions of PHP which include Zend Thread Safety (ZTS) support. Using PDFlib with Zend Server. In order to use PDFlib with Zend Server you must in- stall the DSO php_pdflib.so from the php-<version> directory. Copy this DSO to the exten- sion directory and restart PHP. 6.3 Using the PDFlib DSO Loading the PDFlib DSO in php.ini. If you decide to load PDFlib every time PHP starts, insert the following line in php.ini (adjust the shared library suffix .dll as necessary for your platform, e.g. .so): extension=php_pdflib.dll and restart your Web server so that the changes are recognized. Loading the PDFlib DSO explicitly in your PHP script. Without the extension line in php.ini you must include the following line in your PHP scripts (adjust the shared library suffix .dll as necessary for your platform, e.g. .so): dl("php_pdflib.dll"); In this case your php.ini must contain the following lines: safe_mode=Off enable_dl=On The line extension_dir is not relevant in this case. Note that for security reasons this method is no longer recommended and many Web hosters dont allow it. Using PDFlib with Zend Server. Zend automatically recognizes correctly named exten- sions when PHP is restarted. 6.4 Installing and Using the PDFlib DSO on i5/iSeries Note In order to deploy PDFlib with Zend Server for IBM i you must order a PDFlib license key for AIX, not a license for i5/iSeries. See below for more information. The third-party product Zend Server for IBM i allows you to leverage the power of the IBM i platform and the strength and flexibility of PHP to run business-critical applica- tions on IBM i, see www.zend.com/en/products/server/zend-server-ibm-i The requirements for using PDFlib with PHP on i5/iSeries are as follows: > Zend Server for IBM i or Zend Server Community Edition (CE) for IBM i > PHP 5.3 8 The PDFlib-in-PHP HowTo Zend Server for IBM i is based on the Portable Application Solutions Environment (PASE for i), an integrated runtime for porting selected applications from AIX systems. PASE is not an emulation: since i5/iSeries and AIX are based on the same POWER processor ar- chitecture, PASE uses the processor directly. There are no performance disadvantages when using PASE. More details about PASE can be found on the following IBM Web site: www.ibm.com/partnerworld/wps/servlet/ContentHandler/pw_com_porting_ibmi_pase Perform the following steps to use PDFlib with Zend Server for IBM i: > Since Zend Server and the underlying Apache Web server are based on the PASE envi- ronment, you must use the PDFlib package for AIX, not the PDFlib package for i5/ iSeries. Download the following package from the PDFlib Web site: PDFlib-9.0.x-AIX-php.tar.gz > Unpack the PDFlib package for AIX, using any of the available tools for unpacking .tar.gz packages. > Locate php_pdflib.so and copy it to the extension_dir of Zend Server. The output of phpinfo( ) shows the exact location of this directory. > As an alternative to the previous step you can also load the PDFlib DSO directly from your script without configuring it in php.ini (note that for security reasons this meth- od is no longer recommended): dl("php_pdflib.so"); In this case your php.ini must contain the following lines: safe_mode=Off enable_dl=On Now you can create PDF from PHP scripts on i5/iSeries. 6.5 Common Problems with PDFlib DSOs 6.5.1 All Platforms Binary characteristics of PHP and PDFlib DSO must match. Several properties of your PHP binary must match those of the PDFlib DSO. These properties are determined when building PHP, and cannot be changed afterwards. The precompiled DSOs for PDFlib have been built as follows: > non-debug version > thread-safety as described in Section 6.1, Installing the PDFlib DSO on Windows and Section 6.2, Installing the PDFlib DSO on Unix > the API version: choose the matching version from bind/php/php-<version> If you see an error message similar to the following when trying to load the PDFlib DSO, your PHP build number does not match that of the PDFlib module: Warning: pdf: Unable to initialize module Module compiled with debug=0, thread-safety=0 module API=20020429 PHP compiled with debug=0, thread-safety=1 module API=20020429 All of these options must match. Chapter 6: Deploying the PDFlib DSO 9 Older version of PDFlib built into the PHP binary. PDFlib Lite support must not already have been compiled into your PHP version. If your PHP already includes PDFlib Lite sup- port (this is the case for versions of PHP distributed with some Linux distributions) but you need a newer PDFlib version you must first obtain a PHP binary without builtin PDFlib support (either by locating the appropriate binary, or rebuilding it yourself). Maintainers of Linux and PHP distributions should include PDFlib support for PHP as DSO because this facilitates updates. 6.5.2 Linux x86 and Intel 64 PDFlib with XAMPP on Linux x86. Some versions of system libraries bundled with the XAMPP package may trigger the following error message: Warning: PHP Startup: Unable to load dynamic library '/opt/lampp/htdocs/test/pdf/pdflib/ bind/php/php-530/libpdf_php.so' - /opt/lampp/lib/libgcc_s.so.1: version `GCC_4.2.0' not found (required by /usr/lib/libstdc++.so.6) in Unknown on line 0 In this case you must disable the following two lines in the file bin/envvars, e.g. by add- ing a comment character at the start of the line: #binbuild LD_LIBRARY_PATH="/opt/lampp/lib/:$LD_LIBRARY_PATH" #binbuild export LD_LIBRARY_PATH PDFlib with XAMPP on Linux Intel 64. Since XAMPP is only available as a 32-bit edition you must use the 32-bit edition of PDFlib for this combination. However, you may see the following error message: Warning: PHP Startup: Unable to load dynamic library '/opt/lampp/htdocs/test/pdf/PDFlib-8.0.4-Linux-php/bind/php/php-530/libpdf_php.so' - libstdc++.so.6: wrong ELF class: ELFCLASS64 in Unknown on line 0 The reason for this error is that while XAMPP includes some of the 32-bit runtime librar- ies required for PDFlib, one important runtime library is still missing. You must install the 32-bit version of libstdc++.so.6 on the system. For example, on Debian systems this can be achieved with the following command: apt-get install ia32-libs 6.5.3 OS X Zend Server on OS X. Although the PDFlib DSO works fine with the native PHP version bundled with OS X, there is a problem with Zend Server on OS X. In this environment the server may hang when attempting to use PDFlib, and youll find the following mes- sage in the server log: The process has forked and you cannot use this CoreFoundation functionality safely. You MUST exec(). Break on THE_PROCESS_HAS_FORKED_AND_YOU_CANNOT_USE_THIS_COREFOUNDATION_FUNCTIONALITY___ YOU_MUST_EXEC() to debug. In order to avoid this problem you must disable the host font feature in PDFlib using the following call: PDF_set_option($p, "usehostfonts=false"); 10 The PDFlib-in-PHP HowTo PDFlib with XAMPP or MAMP on OS X 10.6 and older. If you add the PDFlib PHP exten- sion to your php.ini on an OS X Intel machine which has XAMPP installed, the following error message appears: dyld: NSLinkModule() error dyld: Symbol not found: __cg_jpeg_resync_to_restart Referenced from: /System/Library/Frameworks/ApplicationServices.framework/Versions/A/ Frameworks/ImageIO.framework/Versions/A/ImageIO Expected in: /Applications/xampp/xamppfiles/lib/libjpeg.62.dylib The PDFlib extension is linked against the ApplicationServices Framework, and XAMPP changes the DYLD_LIBRARY_PATH. This combination confuses the dynamic link editor. We found that commenting out DYLD_LIBRARY_PATH in xamppfiles/bin/envvars cures this problem. If you have MAMP installed, the following error message may appear in the log file: PHP Warning: PHP Startup: Unable to load dynamic library '/Applications/MAMP/bin/php5.3/ lib/php/extensions/no-debug-non-zts-20090626/libpdf_php.so' - dlopen(/Applications/MAMP/ bin/php5.3/lib/php/extensions/no-debug-non-zts-20090626/libpdf_php.so, 9): Symbol not found: __cg_jpeg_resync_to_restart Referenced from: /System/Library/Frameworks/ApplicationServices.framework/Versions/A/ Frameworks/ImageIO.framework/Versions/A/Resources/libTIFF.dylib Expected in: /Applications/MAMP/Library/lib/libjpeg.8.dylib in /System/Library/Frameworks/ApplicationServices.framework/Versions/A/Frameworks/ ImageIO.framework/Versions/A/Resources/libTIFF.dylib in Unknown on line 0 To cure the problem with MAMP comment out DYLD_LIBRARY_PATH in Library/bin/ envvars. Chapter 7: Additional Web Links 11 7 Additional Web Links > The public PDFlib mailing list for general discussion: tech.groups.yahoo.com/group/pdflib > PDFlib support for commercial licensees: support@pdflib.com > General information on installing PHP: www.php.net/install > PEAR and PECL support: pear.php.net/support.php and pecl.php.net/support.php > Instructions on getting the latest version of PEAR: pear.php.net/manual/en/installation.getting.php > Comprehensive list of PHP-related links: www.php.net/links.php
Installation and Configuration of IBM FileNet Information Management Software: A step-by-step guide to installing and configuring IBM FileNet ECM and Case Manager on RHEL 8.0 (English Edition)
Installation, Upgrade, and Configuration of IBM Cognos Analytics: Smooth Onboarding of Data Analytics and Business Intelligence on Red Hat RHEL 8.0, IBM Cloud Private, and Windows Servers
Installation and Configuration of IBM Watson Analytics and StoredIQ: Complete Administration Guide of IBM Watson, IBM Cloud, Red Hat OpenShift, Docker, and IBM StoredIQ (English Edition)
Installation and Configuration of IBM FileNet Information Management Software: A step-by-step guide to installing and configuring IBM FileNet ECM and Case Manager on RHEL 8.0 (English Edition)
Installation, Upgrade, and Configuration of IBM Cognos Analytics: Smooth Onboarding of Data Analytics and Business Intelligence on Red Hat RHEL 8.0, IBM Cloud Private, and Windows Servers
Installation and Configuration of IBM Watson Analytics and StoredIQ: Complete Administration Guide of IBM Watson, IBM Cloud, Red Hat OpenShift, Docker, and IBM StoredIQ (English Edition)