Instalar mPDF sin compositor – Informes en PDF con PHP

El mPDF genera PDF de HTML/CSS con baja curva de aprendizaje. La idea aquí es hacer el mPDF funciona sin tener que instalar al compositor en el servidor.

Introducción

Hoje em dia já não me vejo programando sem usar o Composer. Ele te permite gerenciar de forma consistente inúmeros módulos/scripts criados por terceiros e que estão disponíveis em https://packagist.org/.

Com o Composer você pode não apenas instalar e atualizar pacotes facilmente, mas também manter sincronizado automaticamente quaisquer dependências com outros pacotes utilizados na aplicação. Por otra parte, já tem prontinho o autoload, permitindo carregar suas classes PHP sem necessidade de fazer include/require.

Mas este não é um Post sobre Composer :P Vamos ver como instalar e executar o mPDF, uma biblioteca PHP para gerar PDF utilizando-se de código HTML. El mPDF tem lá seus contras, mas o interessante é que você basicamente precisa apenas montar seu HTML e com mínimo esforço já terá condições de convertê-lo para PDF.

Problema

Ao que parece, nas novas versões, é preciso do Composer para instalar o mPDF. Por lo tanto, o recomendado é que você de fato passe a usar o Composer em sua atividade de desenvolvimento.

Daí vem a pergunta: e se eu não tiver como instalar o Composer no servidor? En este caso, vamos utilizar de uma artifício: instalar el Composer localmente e então subir (subir) para o Servidor a pastaVendor“. Nestas condições seu Composer vai ficar parcialmente inoperante, mas ainda assim vai tornar possível o uso do mPDF.

Solución

A instalação do mPDF pelo Composer é muito simples. Vá ao site https://getcomposer.org/download/, baixe e instale o Composer.

Uma vez que tenha o Composer instalado, basta abrir o Terminal (comando) e acessar o diretório da sua aplicação (dentro de www/ ou htdocs/, por ejemplo), e então rodar o seguinte comando:

$ compositor require mpdf/mpdf

Note que na raiz do diretório da sua aplicação será criado uns arquivos, como composer.json y composer.lock, bem como o diretórioVendor/“. Agora ficou fácil! Você já tem tudo que precisa para seu mPDF funcionar.

Pegue a pasta Vendor e envie para o seu Servidor. De preferência, coloque-a na raiz e crie um arquivo index.php (também na raiz) para testarmos o mPDF contendo o seguinte código:

1
2
3
4
5
<?PHP
require_once __DIR__ . '/vendor/autoload.php';
$mpdf = nuevo mPDF();
$mpdf->WriteHTML('<H1>Hello world!</H1>');
$mpdf->Output();

Hecho esto, se tudo der certo, irá aparecer um PDF escritoHello World!“.

Informes en PDF con PHP

Relatório não é a finalidade deste Post, mas aproveito para registrar algo mais. Se você precisa gerar relatórios, uma opção é embutir seu CSS/HTML no arquivo PHP e então passar o código para o mPDF fazer o trabalho duro, assim por exemplo (Ver saída na Figura 1 por debajo de):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
<?PHP
require_once __DIR__ . '/vendor/autoload.php';
ob_start();
?>
<estilo>
    tabla, TH, TD {
        frontera: 1px solid black;
        border-collapse: collapse;
        relleno: 5PX;
    }               
    table tr:nth-child(Odd) {
      color de fondo: #eee;
    }  
    table tr:nth-child(incluso) {
      color de fondo: #FFF;
    }   
    table thead th {
      color de fondo: #CCC;
    } 
    table tfoot td {
      color de fondo: #CCC;
    } 
</estilo> 
<H1>Meu Relatório</H1>
<table align="center">
    <CULATA EN T>
        <TR>
            <TH>Nombre</TH>
            <TH>Edad</TH>
            <TH>Correo electrónico</TH>
        </TR>
    </CULATA EN T>
    <tfoot>
        <TR>
            <td colspan="3" align="center">Copyright ® 2017</TD>
        </TR>
    </tfoot>>    
    <TBODY>
        <TR>
            <TD>Taylor</TD>
            <td align="center">43</TD>
            <TD >taylor@amail.com</TD>
        </TR>
        <TR>
            <TD>Portela</TD>
            <td align="center">47</TD>
            <TD>portela@bmail.com</TD>
        </TR>        
    </TBODY>
</tabla>
<?PHP
$HTML = ob_get_contents();
$mpdf = nuevo mPDF;
$mpdf->WriteHTML($HTML);
$mpdf->Output();

Fig. 1 – Arquivo PDF de saída referente à injeção de código CSS/HTML (por encima de) processado pelo mPDF

Obviamente você pode estruturar melhor o código colocando o CSS/HTML em um arquivo de template separado e carregá-lo para dentro da chamada do mPDF.

De todos modos, agora é com você! Dê uma lida no Manual do mPDF e fique por dentro da forma de uso e compatibilidades.

Total hits: 191

Contesta

Su dirección de correo electrónico no será publicado. Campos requeridos están marcados con *