Generating PDF files using CodeIgniter
PDF files rock! Some of the programs used to view them could use some work, but the file format itself is real handy. As a programmer I have found PDF’s to be most helpful when generating reports that need to be printable. I know we are all supposed to be doing our part to make our offices “greener” and use less resources like paper. But some things just need to be printed (especially when your talking about the financial and legal industries).
When generating reports in PDF format you suddenly have a lot more control over layout and design than you do with plain old HTML and CSS (although much progress is being made with print style sheets). You can create some really nice reports on the fly that your users can view, save for later or e-mail to their co-workers for review. In this post I will show you how I generate PDF reports using CodeIgniter.
Quick Note
There are a number of PHP libraries out there for generating PDF files (like FPDF, Panda and dompdf) but the best one I have come across is the R&OS pdf class. I was first introduced to it from the PHP Anthology first edition by Harry Fuecks. I have tried other PDF libraries (some PHP 5 specific and some not) and none of them have been able to provide me with the same control or ease of use that the R&OS class has which is why I’m using it for this tutorial.
Getting Started
Before we start, lets get everyone to the same place so you can follow along as we go. I’ve prepared a .zip file containing everything you’ll need to follow along. The archive includes CI 1.6.3 along with all the code and libraries we will discuss in this tutorial. Simply download the archive, unzip it on your web server and follow along.
I have done all the work of downloading the code library and putting the files in their right place for you, but I wanted to mention where things were for the detail oriented among you. There are 2 files that are necessary in order to use the R&OS library: class.ezpdf.php and class.pdf.php. Those two files have been placed in the application/library folder. R&OS also requires some font files in order to function and they have been placed at the root of the .zip file in a folder called fonts.
You do have to make a minor modification to the class.ezpdf.php file so that it will work properly within CI. First I renamed the file to cezpdf.php, which makes it easier to load using the CI loader. Then you have to modify the include statement on line 3 to:
include_once(APPPATH . 'libraries/class.pdf.php');
This will keep PHP from saying that it can’t find included file. Once those modifications are made the R&OS class is ready to use with CI.
In the archive, I have also made a controller called tutorial.php and a helper called pdf_helper.php both in their respective directories. With the background info. out of the way, lets get our hands dirty with a real simple example.
Hello World
function hello_world()
{
$this->load->library('cezpdf');
$this->cezpdf->ezText('Hello World', 12, array('justification' => 'center'));
$this->cezpdf->ezSetDy(-10);
$content = 'The quick, brown fox jumps over a lazy dog. DJs flock by when MTV ax quiz prog.
Junk MTV quiz graced by fox whelps. Bawds jog, flick quartz, vex nymphs.';
$this->cezpdf->ezText($content, 10);
$this->cezpdf->ezStream();
}
The above code produces a PDF file like this.
In the above, first thing we do is load the R&OS library for use. Next we use the ezText() function to create a title for our document. This function takes the text it will display as the first argument, the size of that text and an optional array of additional configuration options. In this instance we pass along a justification option of center. That will center our title at the top of our document.
After the title we insert some extra white space using the ezSetDy() function. After the whites pace we put the rest of the content for the document in a variable called $content and add it to our document using the ezText() function again. Finally, we create our document using the ezStream() function which actually creates the document and sends it to the users which prompts them to view/download the generated PDF document.
Handling Tabular Data
When your dealing with business reports the odds are good that you will need to generate reports with tables to display tabular data. From my experience with other PDF libraries, this is not an easy task. But with the R&OS library it’s about as hard as creating an array.
function tables()
{
$this->load->library('cezpdf');
$db_data[] = array('name' => 'Jon Doe', 'phone' => '111-222-3333', 'email' => 'jdoe@someplace.com');
$db_data[] = array('name' => 'Jane Doe', 'phone' => '222-333-4444', 'email' => 'jane.doe@something.com');
$db_data[] = array('name' => 'Jon Smith', 'phone' => '333-444-5555', 'email' => 'jsmith@someplacepsecial.com');
$col_names = array(
'name' => 'Name',
'phone' => 'Phone Number',
'email' => 'E-mail Address'
);
$this->cezpdf->ezTable($table_data, $col_names, 'Contact List', array('width'=>550));
$this->cezpdf->ezStream();
}
The above code should produce a PDF file like this.
In the above code I create an array of data called $db_data. I put this together so that it imitates a typical database result set because that’s usually where you will be getting your data from. Below my data array I have created a $col_names array that associates the data elements in the $db_data array with a column title for the table. This is where the R&OS gets the title to display at the top of each table column. Once I have the data and column titles I create the table by calling the ezTable() function. This function takes the data array, an associative array for column names, the title for the table and an optional array of configuration options. There are a number of options that can be configured through that last optional array, but I’m not going to go into them in this tutorial.
Headers and Footers
Most reports in a corporate setting come with some kind of standard header and/or footer. They can include anything from the date/time generated, the user who generated them, to page numbers and the like. Headers and footers are handy to have, but unfortunately there isn’t a real good way to add them to printable reports generated in HTML and CSS. There’s one more reason to use the portable document format when creating printable reports.
The process of adding headers and footers to a PDF using the R&OS library is the slightest bit complicated. There are a lot of lines of code just to accomplish it, that’s why I have created a helper file. Since the code is in a helper function, you just need load the helper and call the function whenever you need to add headers/footers to a PDF.
function prep_pdf($orientation = 'portrait')
{
$CI = & get_instance();
$CI->cezpdf->selectFont(base_url() . '/fonts');
$all = $CI->cezpdf->openObject();
$CI->cezpdf->saveState();
$CI->cezpdf->setStrokeColor(0,0,0,1);
if($orientation == 'portrait') {
$CI->cezpdf->ezSetMargins(50,70,50,50);
$CI->cezpdf->ezStartPageNumbers(500,28,8,'','{PAGENUM}',1);
$CI->cezpdf->line(20,40,578,40);
$CI->cezpdf->addText(50,32,8,'Printed on ' . date('m/d/Y h:i:s a'));
$CI->cezpdf->addText(50,22,8,'CI PDF Tutorial - http://www.christophermonnat.com');
}
else {
$CI->cezpdf->ezStartPageNumbers(750,28,8,'','{PAGENUM}',1);
$CI->cezpdf->line(20,40,800,40);
$CI->cezpdf->addText(50,32,8,'Printed on '.date('m/d/Y h:i:s a'));
$CI->cezpdf->addText(50,22,8,'CI PDF Tutorial - http://www.christophermonnat.com');
}
$CI->cezpdf->restoreState();
$CI->cezpdf->closeObject();
$CI->cezpdf->addObject($all,'all');
}
An example of how I use this helper is provided in the headers() function of the tutorial.php controller. That code produces a PDF file like this.
The above code is the prep_pdf() function located in the pdf_helper.php file. This function does all the hard work of creating a footer for my PDF reports for me. All I have to do is load the helper in my controller and call the function. Since the reports could be portrait or landscape I have also included the ability to pass the orientation to the function and the code will modify the document margins accordingly.
I’m not going to go into a lot of detail about the above code because this tutorial could become very long. But the general idea is that I’m using the R&OS library to modify the margins of the document I’m creating, add page numbers and text to the very bottom of the document. R&OS has some functions that makes this easy like ezStartPageNumbers() and line(). Once all that is done I can add any kind of content to the document back in my controller and then just call ezStream() to generate the final document.
Wrap Up
I barely scratched the surface of what you can do with the R&OS PDF library in this tutorial. I encourage you to spend some quality time with the readme.pdf documentation file that comes with the library when you download it. That file goes over all the functions and their options in great detail.
So there you have it, generating PDF files with CodeIgniter and the R&OS library. If this method doesn’t quite do it for you, there are a few helpful articles on the CodeIgniter wiki, like this one and this one, which walk you through some additional options. Whatever solution you choose I hope this tutorial has helped to introduce you to some of the options you have at your disposale for creating PDF reports with CodeIgniter.
Related posts:
- Building Applications using CodeIgniter (Part 3) – Helpers
- Building Applications using CodeIgniter (Part 4) – Code Templates
- How to use reCAPTCHA with CI
- How-to Ensure a Secure Connection Using PHP
- Building Applications using CodeIgniter (Part 2) – Configuration
If you enjoyed this post, please consider to leave a comment or subscribe to the feed and get future articles delivered to your feed reader.

Hi. thanks for tutorial.
I need Code Igniter to generate pdf invoice.
in function “function tables()” there is a variable $table_data.
Where was it come from? was it you who make mistake?
I am using your tutorial and found nothing in pdf file when using tables(), than i change it with $db_data.
but anyway, thx a lot for the tutorial.
Donnie, your right… I should be passing $db_data instead of $table_data. I will update my code.
Thanks!
Have you had any problems with ezNewPage()? I get an error as I scroll down to the new page. Just says “An error exists on the page”. If I click OK button, I can continue and not get that error again until I regenerate the PDF.
Great tutorial! It’s helped me tremendously.
Joe: No, I haven’t experienced this problem before… and I use the ezNewPage() function extensively. That’s strange!
The only thing I can guess is that somehow the PDF file is getting corrupted or somehow screwed up during generation. I hesitate to point the finger at your web server, but I’m not sure what else it could be. Are you using Adobe reader to view the file? If so, you might want to try a different reader and see if you get the same error message.
Sorry I can’t be of more help… let me know if you find a resolution.
Found the resolution: UPGRADE the reader!
I upgraded to the latest Adobe and no more error.
Thanks!
is that posible in cezpdf if i need to insert an image?
could you tell how? thanks before.
I am using cezpdf with CI (with pdf_helper) to generate reports and works great! However I am stumped as to how to change the paper orientation to landscape. The constructor is where the orientation is set except I am not able to make any of my reports print in landscape. They always come out in portrait mode. Any help is appreciated!
LDG: If you are using my helper function that I provided above then that is where the paper orientation is being set. By Default it will be set to portrait unless you pass a different orientation to the prep_pdf() helper function.
I have had problems with the libraries built in orientations in the past which is why I set my own margins in the helper function using the $CI->cezpdf->ezSetMargins(); function. You might be better off just setting your own margins and going on from there.
Chris: Thanks for your response. I am using your helper function and am passing “landscape” for the orientation. The output prints using my landscape format but the paper orientation is still 8.5 x 11. I can’t get the paper to orient to 11 x 8.5. But if I change the default parameter in the cezpdf class to “landscape” from “portrait” then the papersize changes to 11 x 8.5. But then my “portrait” reports will not work.
I can’t figure out how you pass the orientation parameter to the cezpdf class. I tried $CI->cezpdf(‘LETTER’,'landscape’) but this does not work. Let me know if you want me to send you my code.
I got it! I knew it was a just a simple thing I was missing!
after getting the CI instance,
$CI->cezpdf->cezpdf($paper,$orientation);
I changed your pdf helper to also pass the paper-size so I can control both parameters.
Hi,
I need one help, My requirement to to create PDF file with lots of images. I read the document of R&OS PDF, and found that it only add the image with the type jpeg and png to the document.
Is there any work around to include gif images in the pdfs.
Advise me is there any good pdf class available apart from R&OS PDF.
Thanks in advance
Hi ashok, there are plenty of alternatives to the R&OS class and I mentioned some of them in the post under Quick Note near the beginning. Please refer there for more information.
Looks nice, but your archive doesn’t contain the aformentioned readme.pdf and I can’t find it anywhere on your site…
Hi daniel, the readme.pdf file comes with the R&OS PDF class. When you download and extract the code library there should be a readme.pdf file along with them. That’s the file I’m referring to.
Thank you for sharing these services
Very usefull tutorial. Thanks.
For some strange reason I keep getting a lot of errors like these:
A PHP Error was encountered
Severity: Notice
Message: Undefined index:
Filename: libraries/class.pdf.php
Line Number: 1935
At the bottom some strange characters show op (the beginning of a pdf-file): %PDF-1.3 %âãÏÓ…
But only with hello_world() and headers().
When I render the tables() function, it only shows a blank PDF.
What could this be?
Thanks in advance.
Hi Jan, that’s pretty odd. If I were you I would be checking versions of PHP and such to make sure the PDF library can run in your environment. I find that server incompatibility can cause odd results like the one you are seeing.
Thank you for a nice post, I’ve tried it and I think that it suits my requirement.
Very nice and easy to use tutorial. I’m going to use this solution.
How do you add images? I tried $this->cezpdf($img); text renders but no image. I’ve tried both relative and full paths to the image. No luck. Any ideas? Thanks in advance.
CORRECTION TO LAST: $this->cezpdf->ezImage($img); But still no image?
Hi,
i liked this library very much and want to integrate it in my application but i am also getting the same kind of errors mentioned by Jan Cornelissen :
A PHP Error was encountered
Severity: Notice
Message: Undefined index:
Filename: libraries/class.pdf.php
Line Number: 1934(also getting the same error on different lines as well)
The code in downloaded archives is working fine, but if i put the same files in my own application then it is showing many errors with message : undefined index
what i did is :-
1. copied the files from download archived controller,library folder to my application’s folder, and also copied the fonts from your folder to mine.
please tell me the way to remove these errors
Thanks
Piyush
Hi, problem is fixed by just placing the font folder on the root location.
earlier i was putting the font folder inside the applications folder,