PDFlib in PHP HowTo
PDFlib in PHP HowTo
Last change: May 8, 2013 Latest PDFlib version covered in this document: 9.0.1 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
May 8, 2013
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 extension 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 includes 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
May 8, 2013
We also offer Windows binaries of the PDFlib PHP binding which have been built without 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/libpdf_php.dll bind/php/php-<version>-nozts/php_pdflib.dll (PDFlib 8) (PDFlib 9)
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 distribution 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 9 with Zend Server you must install the DLL php_pdflib.dll from the php-<version>-nozts_VS9 directory. Copy this DLL to the extension directory and restart PHP. For PDFlib 8 you must rename libpdf_php.dll to php_pdf.dll to make sure that the extension will automatically be recognized by PHP.
May 8, 2013
Copy the PDFlib DSO to the directory which is specified in the extension_dir line in php.ini. The standard Unix versions of the PDFlib DSO have been built without multithread support. However, the binaries
bind/php/php-<version>mt/libpdf_php.so bind/php/php-<version>mt/php_pdflib.so (PDFlib 8) (PDFlib 9)
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 9 with Zend Server you must install the DSO php_pdflib.so from the php-<version> directory. Copy this DSO to the extension directory and restart PHP. For PDFlib 8 you must rename libpdf_php.so to php_pdf.so to make sure that the extension will automatically be recognized by PHP.
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("libpdf_php.dll"); dl("php_pdflib.dll"); (PDFlib 8) (PDFlib 9)
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.
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 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 architecture, 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 environment, 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-8.0.x-AIX-php.tar.gz PDFlib-9.0.x-AIX-php.tar.gz (PDFlib 8) (PDFlib 9)
> Unpack the PDFlib package for AIX, using any of the available tools for unpacking .tar.gz packages. > Locate libpdf_php.so (PDFlib 8) or php_pdflib.so (PDFlib 9) and copy it to the extension_ dir of Zend Server. The output of phpinfo( ) shows the exact location of this directory. > PDFlib 8 only: rename the copy of libpdf_php.so to php_pdf.so to match the naming conventions used in Zend Server. > 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 method is no longer recommended):
dl("php_pdflib.so");
May 8, 2013
All of these options must match. 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 support (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.
In this case you must disable the following two lines in the file bin/envvars, e.g. by adding 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 libraries 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
PDFlib with XAMPP or MAMP on OS X 10.6 and older. If you add the PDFlib PHP extension 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.
10
May 8, 2013
11