All Projects → PHPJasper → Phpjasper

PHPJasper / Phpjasper

Licence: mit
A PHP report generator

Projects that are alternatives of or similar to Phpjasper

Openpdf
OpenPDF is a free Java library for creating and editing PDF files with a LGPL and MPL open source license. OpenPDF is based on a fork of iText. We welcome contributions from other developers. Please feel free to submit pull-requests and bugreports to this GitHub repository. ⛺
Stars: ✭ 2,174 (+564.83%)
Mutual labels:  hacktoberfest, pdf-generation
Rst2pdf
Use a text editor. Make a PDF.
Stars: ✭ 404 (+23.55%)
Mutual labels:  hacktoberfest, pdf-generation
Rigel
🌌 Colorscheme for vim, terminal, vscode and slack - based on the star Rigel ✨.
Stars: ✭ 324 (-0.92%)
Mutual labels:  hacktoberfest
Cds
Enterprise-Grade Continuous Delivery & DevOps Automation Open Source Platform
Stars: ✭ 3,677 (+1024.46%)
Mutual labels:  hacktoberfest
Mysql
Sous Chefs MySQL Cookbook
Stars: ✭ 325 (-0.61%)
Mutual labels:  hacktoberfest
Code
Code editor designed for elementary OS
Stars: ✭ 324 (-0.92%)
Mutual labels:  hacktoberfest
Devicekit
DeviceKit is a value-type replacement of UIDevice.
Stars: ✭ 3,566 (+990.52%)
Mutual labels:  hacktoberfest
Kiimagepager
The KIImagePager is inspired by foursquare's ImageSlideshow, the user may scroll through images loaded from the Web
Stars: ✭ 324 (-0.92%)
Mutual labels:  hacktoberfest
Portainer
Making Docker and Kubernetes management easy.
Stars: ✭ 20,434 (+6148.93%)
Mutual labels:  hacktoberfest
Postgresql
Development repository for the postgresql cookbook
Stars: ✭ 326 (-0.31%)
Mutual labels:  hacktoberfest
Luvit
Lua + libUV + jIT = pure awesomesauce
Stars: ✭ 3,443 (+952.91%)
Mutual labels:  hacktoberfest
Django X509
Reusable django app implementing x509 PKI certificates management
Stars: ✭ 326 (-0.31%)
Mutual labels:  hacktoberfest
Launchpad
An open-source game launcher for your games
Stars: ✭ 322 (-1.53%)
Mutual labels:  hacktoberfest
Macos big sur icons replacements
Replacement icons for popular apps in the style of macOS Big Sur
Stars: ✭ 3,608 (+1003.36%)
Mutual labels:  hacktoberfest
Teachcode
A tool to develop and improve a student’s programming skills by introducing the earliest lessons of coding.
Stars: ✭ 325 (-0.61%)
Mutual labels:  hacktoberfest
Jenkins
Jenkins automation server
Stars: ✭ 18,225 (+5473.39%)
Mutual labels:  hacktoberfest
Pokemon Showdown Client
The client for Pokémon Showdown
Stars: ✭ 321 (-1.83%)
Mutual labels:  hacktoberfest
Pathfinding
Pathfinding library for rust
Stars: ✭ 324 (-0.92%)
Mutual labels:  hacktoberfest
J.a.r.v.i.s
python powered Intelligent System
Stars: ✭ 325 (-0.61%)
Mutual labels:  hacktoberfest
Osquery
SQL powered operating system instrumentation, monitoring, and analytics.
Stars: ✭ 18,475 (+5549.85%)
Mutual labels:  hacktoberfest

PHPJasper logo

PHPJasper

A PHP Report Generator

Build Status Coverage Status Latest Stable Version Minimum PHP Version Total Downloads License PHPStan All Contributors

Docs

Language-pt_BR

About

PHPJasper is the best solution to compile and process JasperReports (.jrxml & .jasper files) just using PHP, in short: to generate reports using PHP.

Our channel on discord

https://discord.gg/7FpDnQ

Notes:

  • PHPJasper Can be used regardless of your PHP Framework
  • For PHP versions less than 7.0 see: v1.16
  • Here are several examples of how to use PHPJasper

Why PHPJasper?

Did you ever had to create a good looking Invoice with a lot of fields for your great web app?

I had to, and the solutions out there were not perfect. Generating HTML + CSS to make a PDF? That doesn't make any sense! :)

Then I found JasperReports the best open source solution for reporting.

What can I do with this?

Well, everything. JasperReports is a powerful tool for reporting and BI.

From their website:

The JasperReports Library is the world's most popular open source reporting engine. It is entirely written in Java and it is able to use data coming from any kind of data source and produce pixel-perfect documents that can be viewed, printed or exported in a variety of document formats including HTML, PDF, Excel, OpenOffice and Word.

It is recommended using Jaspersoft Studio to build your reports, connect it to your datasource (ex: MySQL, POSTGRES), loop thru the results and output it to PDF, XLS, DOC, RTF, ODF, etc.

Some examples of what you can do:

  • Invoices
  • Reports
  • Listings

Requirements

  • PHP 7.2 or above
  • Java JDK 1.8

Optional

Installation

Install Composer if you don't have it.

composer require geekcom/phpjasper

Or in your file'composer.json' add:

{
    "require": {
        "geekcom/phpjasper": "^3.2.0"
    }
}

And the just run:

composer install

and thats it.


PHPJasper with Docker

With Docker CE and docker-compose installed just run:

  • docker-compose up -d
  • docker exec -it phpjasper composer install

To execute tests:

  • docker exec -it phpjasper sudo composer test or
  • docker exec -it phpjasper sudo composer testdox

To see coverage manually of tests, execute the file: tests/log/report/index.html

Help us writing new tests, make a fork :)


Examples

The Hello World example.

Go to the examples directory in the root of the repository (vendor/geekcom/phpjasper/examples). Open the hello_world.jrxml file with Jaspersoft Studio or with your favorite text editor and take a look at the source code.

Compiling

First we need to compile our JRXML file into a JASPER binary file. We just have to do this one time.

Note 1: You don't need to do this step if you are using Jaspersoft Studio. You can compile directly within the program.

require __DIR__ . '/vendor/autoload.php';

use PHPJasper\PHPJasper;

$input = __DIR__ . '/vendor/geekcom/phpjasper/examples/hello_world.jrxml';   

$jasper = new PHPJasper;
$jasper->compile($input)->execute();

This commando will compile the hello_world.jrxml source file to a hello_world.jasper file.

Processing

Now lets process the report that we compile before:

require __DIR__ . '/vendor/autoload.php';

use PHPJasper\PHPJasper;

$input = __DIR__ . '/vendor/geekcom/phpjasper/examples/hello_world.jasper';  
$output = __DIR__ . '/vendor/geekcom/phpjasper/examples';    
$options = [ 
    'format' => ['pdf', 'rtf'] 
];

$jasper = new PHPJasper;

$jasper->process(
    $input,
    $output,
    $options
)->execute();

Now check the examples folder! :) Great right? You now have 2 files, hello_world.pdf and hello_world.rtf.

Check the methods compile and process in src/JasperPHP.php for more details

Listing Parameters

Querying the jasper file to examine parameters available in the given jasper report file:

require __DIR__ . '/vendor/autoload.php';

use PHPJasper\PHPJasper;

$input = __DIR__ . '/vendor/geekcom/phpjasper/examples/hello_world_params.jrxml';

$jasper = new PHPJasper;
$output = $jasper->listParameters($input)->execute();

foreach($output as $parameter_description)
    print $parameter_description . '<pre>';

Using database to generate reports

We can also specify parameters for connecting to database:

require __DIR__ . '/vendor/autoload.php';

use PHPJasper\PHPJasper;    

$input = '/your_input_path/your_report.jasper';   
$output = '/your_output_path';
$options = [
    'format' => ['pdf'],
    'locale' => 'en',
    'params' => [],
    'db_connection' => [
        'driver' => 'postgres', //mysql, ....
        'username' => 'DB_USERNAME',
        'password' => 'DB_PASSWORD',
        'host' => 'DB_HOST',
        'database' => 'DB_DATABASE',
        'port' => '5432'
    ]
];

$jasper = new PHPJasper;

$jasper->process(
        $input,
        $output,
        $options
)->execute();

Note 2:

For a complete list of locales see Supported Locales

Using MSSQL DataBase

require __DIR__ . '/vendor/autoload.php';

use PHPJasper\PHPJasper;

$input = '/your_input_path/your_report.jasper or .jrxml';   
$output = '/your_output_path';
$jdbc_dir = __DIR__ . '/vendor/geekcom/phpjasper/bin/jaspertarter/jdbc';
$options = [
    'format' => ['pdf'],
    'locale' => 'en',
    'params' => [],
    'db_connection' => [
        'driver' => 'generic',
        'host' => '127.0.0.1',
        'port' => '1433',
        'database' => 'DataBaseName',
        'username' => 'UserName',
        'password' => 'password',
        'jdbc_driver' => 'com.microsoft.sqlserver.jdbc.SQLServerDriver',
        'jdbc_url' => 'jdbc:sqlserver://127.0.0.1:1433;databaseName=Teste',
        'jdbc_dir' => $jdbc_dir
    ]
];

$jasper = new PHPJasper;

$jasper->process(
        $input,
        $output,
        $options
    )->execute();

Reports from a XML

require __DIR__ . '/vendor/autoload.php';

use PHPJasper\PHPJasper;

$input = '/your_input_path/your_report.jasper';   
$output = '/your_output_path';
$data_file = __DIR__ . '/your_data_files_path/your_xml_file.xml';
$options = [
    'format' => ['pdf'],
    'params' => [],
    'locale' => 'en',
    'db_connection' => [
        'driver' => 'xml',
        'data_file' => $data_file,
        'xml_xpath' => '/your_xml_xpath'
    ]
];

$jasper = new PHPJasper;

$jasper->process(
    $input,
    $output,
    $options
)->execute();

Reports from a JSON

require __DIR__ . '/vendor/autoload.php';

use PHPJasper\PHPJasper;

$input = '/your_input_path/your_report.jasper';   
$output = '/your_output_path';

$data_file = __DIR__ . '/your_data_files_path/your_json_file.json';
$options = [
    'format' => ['pdf'],
    'params' => [],
    'locale' => 'en',
    'db_connection' => [
        'driver' => 'json',
        'data_file' => $data_file,
        'json_query' => 'your_json_query'
    ]
];

$jasper = new PHPJasper;

$jasper->process(
    $input,
    $output,
    $options
)->execute();

Performance

Depends on the complexity, amount of data and the resources of your machine (let me know your use case).

I have a report that generates a Invoice with a DB connection, images and multiple pages and it takes about 3/4 seconds to process. I suggest that you use a worker to generate the reports in the background.

Thanks

Cenote GmbH for the JasperStarter tool.

JetBrains for the PhpStorm and all great tools.

Questions?

Open a new Issue or look for a closed issue

License

MIT

Contribute

Contributors ✨

Thanks goes to these wonderful people (emoji key):


Daniel Rodrigues

🚇 🚧 💻

Leandro Bitencourt

💻

Vitor Mattos

💻

Rafael Queiroz

💻

Dave Bould

💻

ThiagoAlves31

💻

Jadson Ribeiro

💻

Fernando Boaglio

💻

Rahul Jain

💻

Luiz Eduardo

💻

David Ribeiro

💻

James Allen

💻

This project follows the all-contributors specification. Contributions of any kind welcome!

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].