2017 © Pedro Peláez
 

library phpjasper7

Gerador de relatórios PHP

image

copam/phpjasper7

Gerador de relatórios PHP

  • Tuesday, March 6, 2018
  • by geekcom
  • Repository
  • 1 Watchers
  • 0 Stars
  • 45 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 39 Forks
  • 0 Open issues
  • 5 Versions
  • 10 % Grown

The README.md

PHPJasper

Scrutinizer Code Quality Latest Stable Version Minimum PHP Version License, (*1)

Sobre a biblioteca

PHPJasper é a solução perfeita para compilar e processar relatórios Jasper (.jrxml & .jasper) com PHP, ou seja, gerar relatórios com PHP., (*2)

Notas: * Versão para o PHP 7.0 em diante * PHPJasper pode ser usado independente de seu Framework * Forneça as permissões devidas aos arquivos dentro da pasta vendor/copam/phpjasper7/src/JasperStarter/bin/, (*3)

Por quê preciso do PHPJasper?

Alguma vez você precisou de um relatório simples ou complexo em PHP para seu sistema web?, (*4)

Eu já precisei e fui em busca de algumas soluções, a maioria delas é complexa e você precisa escrever HTML + CSS para gerar um PDF, isso não faz sentido, além de ser muito trabalhoso :), (*5)

Apresento para vocês JasperReports a melhor solução open source que existe para relatórios., (*6)

O que eu posso fazer com isso?

Texto extraido do site JasperSoft:, (*7)

A biblioteca JasperReports é o mecanismo de geração de relatórios de código aberto mais popular do mundo. É inteiramente escrito em Java e é capaz de usar dados provenientes de qualquer tipo de fonte de dados e gerar documentos perfeitos que podem ser visualizado, impressom ou exportadom em uma variedade de formatos de documentos, incluindo HTML, PDF, Excel, OpenOffice e Word ., (*8)

Exemplos do que você pode fazer:, (*9)

  • Faturas
  • Relatórios
  • Listas

Requisitos

  • PHP 7.0 em diante
  • Java JDK 1.8

Opcional

Instalando o Java(JDK)

Verifique se o JDK está instalado:, (*10)

$ javac -version
javac version 1.8.0_101

Se você receber a resposta:, (*11)

command not found: javac

Então você precisa instalar, para o (Ubuntu/Debian) rode o comando:, (*12)

$ sudo apt-get install default-jdk

Para instalar no (centOS/Fedora) faça o seguinte:, (*13)

# yum install java-1.8.0-openjdk.x86_64

Para instalar no Windows visite o link-> JDK e veja qual a versão mais apropriada para o seu Sistema Operacional., (*14)

Agora rode novamente o comando javac -version e veja se deu tudo certo., (*15)


Instalando a biblioteca PHPJasper

Instale o Composer, e rode o comando:, (*16)

composer require copam/phpjasper7

Ou crie um arquivo 'composer.json' e adicione o trecho:, (*17)

{
    "require": {
        "copam/phpjasper7": "^1.0"
    }
}

E execute o comando:, (*18)

composer install

é isso, você tem a biblioteca instalada e pronta para uso., (*19)


Exemplos

Hello World PHPJasper.

Vá para o diretório de exemplos na raiz do repositório (vendor/copam/phpjasper7/exemplos). Abra o arquivo hello_world.jrxml com o JasperStudio ou seu editor favorito e dê uma olhada no código., (*20)

Compilando

Primeiro precisamos compilar o arquivo com a extensão .JRXML em um arquivo binário do tipo .JASPER, (*21)

Nota 1: Caso você não queira usar o Jaspersoft Studio. É possivel compilar o seu arquivo .jrxml da seguinte forma:, (*22)


require __DIR__ . '/vendor/autoload.php'; use PHPJasper\PHPJasper; $input = __DIR__ . 'vendor/copam/phpjasper7/exemplos/hello_world.jrxml'; $jasper = new PHPJasper; $jasper->compile($input)->execute();

Esse comando compila o arquivo fonte hello_world.jrxml em um arquivo binário hello_world.jasper., (*23)

Processando

Agora vamos processar o nosso relatório que foi compilado acima:, (*24)

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

use PHPJasper\PHPJasper;

$input = __DIR__ . 'vendor/copam/phpjasper7/exemplos/hello_world.jasper';  
$output = __DIR__ . '/vendor/copam/phpjasper7/exemplos';    
$options = [ 
    'format' => ['pdf', 'rtf'] 
];

$jasper = new PHPJasper;

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

Agora olhe a pasta /exemplos :) Ótimo trabalho? Você tem 2 arquivos, hello_world.pdf e hello_world.rtf., (*25)

Listando parâmetros

Como consultar o arquivo jrxml para examinar os parâmetros disponíveis no relatório:, (*26)


require __DIR__ . '/vendor/autoload.php'; use PHPJasper\PHPJasper; $input = __DIR__ . 'vendor/copam/phpjasper7/exemplos/hello_world_params.jrxml'; $jasper = new PHPJasper; $output = $jasper->listParameters($input)->execute(); foreach($output as $parameter_description) print $parameter_description . ' < pre>';

Relatórios a partir de um banco de dados

Adicione os parâmetros específicos para conexão com seu banco de dados: MYSQL, POSTGRES ou MSSQL:, (*27)

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

use PHPJasper\PHPJasper;    

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

$jasper = new PHPJasper;

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

Nota 2:, (*28)

Para a lista completa de idiomas suportados veja o link Supported Locales, (*29)

Relatórios com banco de dados MSSQL

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/copam/phpjasper7/exemplos/bin/jaspertarter/jdbc';
$options = [
    'format' => ['pdf'],
    'locale' => 'pt_BR',
    '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();

Relatórios a partir de um arquivo 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' => 'pt_BR',
    'db_connection' => [
        'driver' => 'xml',
        'data_file' => $data_file,
        'xml_xpath' => '/your_xml_xpath'
    ]
];

$jasper = new PHPJasper;

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

Relatórios a partir de um arquivo 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' => 'pt_BR',
    'db_connection' => [
        'driver' => 'json',
        'data_file' => $data_file,
        'json_query' => 'your_json_query'
    ]
];

$jasper = new PHPJasper;

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

MySQL

Incluímos o MySQL connector (v5.1.39) na pasta /src/JasperStarter/jdbc/, (*30)

PostgreSQL

Incluímos também o PostgreSQL (v9.4-1203) na pasta /src/JasperStarter/jdbc/, (*31)

MSSQL

Microsoft JDBC Drivers 6.0, 4.2, 4.1, and 4.0 for SQL Server ., (*32)

Performance

Depende da complexidade do seu relatório., (*33)

Agradecimentos

Cenote GmbH pelo JasperStarter tool., (*34)

JetBrains pelo PhpStorm e seu grande apoio., (*35)

Dúvidas?

Abra uma Issue ou procure por Issues antigas, (*36)

Licença

MIT, (*37)

Contribuição

Contribua com a comunidade PHP, faça um fork !!, (*38)

The Versions

06/03 2018

dev-master

9999999-dev

Gerador de relatórios PHP

  Sources   Download

MIT

The Requires

  • php >=7.0

 

The Development Requires

pdf relatórios

06/03 2018

v1.2

1.2.0.0

Gerador de relatórios PHP

  Sources   Download

MIT

The Requires

  • php >=7.0

 

The Development Requires

pdf relatórios

06/03 2018

v1.1

1.1.0.0

Gerador de relatórios PHP

  Sources   Download

MIT

The Requires

  • php >=7.1

 

The Development Requires

pdf relatórios

06/03 2018

dev-develop

dev-develop

Gerador de relatórios PHP

  Sources   Download

MIT

The Requires

  • php >=7.1

 

The Development Requires

pdf reports php-reports relatórios

24/08 2017

v1.0

1.0.0.0

Gerador de relatórios PHP

  Sources   Download

MIT

The Requires

  • php >=7.1

 

The Development Requires

pdf relatórios