Jump to content
Vitor G. Delgallo

[Resolvido] mPDF - Instalação Manual e Implementação em Projeto com Codeigniter

Recommended Posts

Bom dia,

Estou desenvolvendo um projeto que necessita da implementação do mPDF para gerar relatórios, no entanto, não consegui de nenhuma maneira, implementa-lo em meu projeto.
Gostaria de implementar a seguinte versão do mPDF por ser a mais recente:
 - https://github.com/mpdf/mpdf

Se alguém pudesse me ajudar eu agradeceria muito!! (Gostaria de implementar-lo manualmente no meu projeto, não via composer, pois nunca utilizei composer e também não sei como ativar os comandos via CMD para a instalação).

Segue a lista de como tentei implementar o mPDF:
 - Copiei os arquivos do mPDF para a pasta "application/third_party/mpdf" do Codeigniter;
 - Criei uma library dentro da pasta "application/libraries" do Codeigniter com o nome de "m_pdf_lib.php";
 - Dentro dessa biblioteca, coloquei o seguinte código:

<?php if (!defined('BASEPATH')) exit('No direct script access allowed');

include_once APPPATH . '/third_party/mpdf/src/Mpdf.php';

class m_pdf_lib {
    private $paramsLibrary = '"en-GB-x","A4","","",10,10,10,10,6,3';
    private $pdfLibrary;

    public function __construct() {
    }
    
    public function getParamsLibrary(){
        return $this->paramsLibrary;
    }
    
    public function setParamsLibrary($newParamsLibrary){
        $this->paramsLibrary = $newParamsLibrary;
        return true;
    }
    
    public function getPdfLibrary(){
        return $this->pdfLibrary;
    }
    
    public function setPdfLibrary(){
        $this->pdfLibrary = new \Mpdf\Mpdf($this->paramsLibrary);
        return true;
    }
}

 

 - E então, dentro da minha controller Default de teste, eu coloquei o seguinte código:

<?php
    defined('BASEPATH') OR exit('No direct script access allowed');

    class Teste extends CI_Controller {
        public function __construct() {
            parent::__construct();

            $this->load->library('m_pdf_lib');
        }
    
        public function testePDF(){
            $this->m_pdf_lib->setPdfLibrary();
            $mpdf = $this->m_pdf_lib->getPdfLibrary();

            $html = '<br><br><br>teste<br><br><br>';
            $file = "Relatorio.pdf";
    
            $mpdf->WriteHTML($html);
            $mpdf->Output($file, 'D');
        }
    }


PS: Já tentei ver vídeos e artigos tutoriais sobre isso, mas todos, apenas ensinam à implementar as versões antigas do mesmo (que também não funcionam no meu projeto), ou ensinam a versão mais recente via composer, algo com o qual nunca tive contato e não sei como usar.

Desculpem qualquer incomodo e obrigado desde já!!!

Share this post


Link to post
Share on other sites

Boa noite. Siga este tutorial que dará certo:

 

http://www.universidadecodeigniter.com.br/gerando-pdf-no-codeigniter-com-mpdf/

 

Você deverá instalar o mPDF via composer. A nova versão não tem jeito, terá que ser via composer. Uma vez instalado, você pode copiar a pasta vendor e usar em outros projetos sem a necessidade de instalação novamente via composer.

  • Obrigado! 1

Share this post


Link to post
Share on other sites
19 horas atrás, Alaerte Gabriel disse:

Boa noite. Siga este tutorial que dará certo:

 

http://www.universidadecodeigniter.com.br/gerando-pdf-no-codeigniter-com-mpdf/

 

Você deverá instalar o mPDF via composer. A nova versão não tem jeito, terá que ser via composer. Uma vez instalado, você pode copiar a pasta vendor e usar em outros projetos sem a necessidade de instalação novamente via composer.

Valeu mano, havia olhado esse site já anteriormente, mas os links estavam quebrados... Acredito que deve ter sido devido a internet, pois agora eles estão funcionando...

Valeu mesmo mano, tinha tentado de tudo já, até desisti e comecei a usar o PHPExcel para gerar os relatórios kkkkkk
Quando eu tiver um tempinho, sigo o tutorial e te dou um feedback!!

Share this post


Link to post
Share on other sites
Em 11/11/2017 at 01:36, Alaerte Gabriel disse:

Boa noite. Siga este tutorial que dará certo:

 

http://www.universidadecodeigniter.com.br/gerando-pdf-no-codeigniter-com-mpdf/

 

Você deverá instalar o mPDF via composer. A nova versão não tem jeito, terá que ser via composer. Uma vez instalado, você pode copiar a pasta vendor e usar em outros projetos sem a necessidade de instalação novamente via composer.


FUNCIONOOOOUUUU MANOOOOOO!!!! Valeu mesmo, você não tem noção do quanto eu agradeço!
Tive alguns problemas com as variáveis de ambiente do composer no tutorial que você me mando, então eu meio que segui um cross over desse tutorial com esse para instalar o composer em CMD: http://webdevzoom.com/how-to-install-composer-on-windows/

Então eu consegui outro tutorial para organizar melhor meu projeto.
Talvez depois eu faça um vídeo explicando exatamente oque eu fiz e poste o link dele aqui, só para que ninguém tenha o mesmo problema que eu tive.

Mais uma vez, obrigado mesmo!!!

  • Haha 1

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Samuel Pietro
      Tenho um select em PDO e preciso que a consulta retornada vire uma variavel, mas a variavel só pega a ultima linha da tabela e eu preciso que pegue todas as linhas que existirem.
       
      $conexao = conexao::getInstance(); $sql = 'SELECT * FROM RegistroE'; $stm = $conexao->prepare($sql); $stm->execute(); $Sql = $stm->fetchAll(PDO::FETCH_OBJ); foreach ($Sql as $SqlReg): $conteudo_meio = picture_X($SqlReg->E_01,1) .picture_X($SqlReg->E_02,25) .picture_9($SqlReg->E_03,4) .picture_X($SqlReg->E_04,14) .picture_9($SqlReg->E_05,8) .picture_9($SqlReg->E_06,8) .picture_9($SqlReg->E_07,8) .picture_9($SqlReg->E_08,8) .picture_9($SqlReg->E_09,8) .complementoRegistro(96,"brancos") .picture_9($SqlReg->E_11,1) .complementoRegistro(1,"brancos") ; endforeach; Como eu poderia está fazendo isto?
    • By peterstefan
      Bom dia, estou fazendo uma cadastro via rest e estou utilizando o curl para cadastrar no webservice...
      Meu código está cadastrando tudo certinho, porem quando ele cadastra e mostra o retorno que foi cadastrado com sucesso ele fica o AGUARDE, CARREGANDO e não para.. não sei oque esta faltando pq já tentei varias coisas e não deu certo... 
       
       
       
      $Data = [ "nomeRazaoSocial" => $PostData['nomeRazaoSocial'], "identMF" => $PostData['identMF'], "email" => $PostData['email'], "telefone" => $PostData['telefone'], "senhaProvisoria" => $PostData['senhaProvisoria'] ]; $DataString = json_encode($Data); $curl = curl_init(WEBSERVICECADASTRO); curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "POST"); curl_setopt($curl, CURLOPT_POSTFIELDS, $DataString); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); curl_setopt($curl, CURLOPT_HTTPHEADER, array( 'Content-Type: application/json', 'Content-Length: ' . strlen($DataString)) ); $result = curl_exec($curl); if ($result) { $jSON['success'] = "<i class='icon-checkmark'></i>Pronto, cadastro foi realizado com sucesso!"; }else{ $jSON['error'] = "<i class='icon-warning'></i>Oops! Erro ao cadastrar! Por favor, tente novamente!"; }  

       

    • By RSN
      Boa Noite,
      Preciso enviar uma consulta sql no corpo do e-mail, porém não estou conseguindo concatenar o laço while.
      <?php include_once('conexao.php'); require 'PHPMailer/PHPMailerAutoload.php'; $resultado = mysql_query("SELECT * FROM cupom WHERE FlagEstorno = 1;"); $linhas = mysql_num_rows($resultado); $mensagem = '<div class="x_content"> <table id="datatable-buttons" class="table table-striped table-bordered"> <thead> <tr> <th>Loja</th> <th>Nro Cupom</th> <th>Data</th> <th>Operador</th> </tr> </thead> <tbody> while($linhas = mysql_fetch_array( $resultado)){ echo " <tr>"; echo "<td>".$linhas['nroloja']."</td>"; echo "<td>".$linhas['NroCupom']."</td>"; echo "<td>".$linhas['DataProc']."</td>"; echo "<td>".$linhas['Operador']."</td>"; echo " </tr>"; }'; $mail = new PHPMailer(); $mail->isSMTP(); $mail->Host = 'smtp.gmail.com'; $mail->SMTPAuth = true; $mail->SMTPSecure = 'tls'; $mail->Username = ''; $mail->Password = ''; $mail->Port = 587; $mail->setFrom(''); $mail->addReplyTo(''); $mail->addAddress('', 'Nome'); $mail->isHTML(true); $mail->Subject = 'Assunto do email'; $mail->Body = $mensagem; $mail->AltBody = 'Para visualizar essa mensagem acesse http://site.com.br/mail'; //$mail->addAttachment('/tmp/image.jpg', 'nome.jpg'); if(!$mail->send()) { echo 'Não foi possível enviar a mensagem.<br>'; echo 'Erro: ' . $mail->ErrorInfo; } else { echo 'Mensagem enviada.'; } ?>  
    • By Augustomesquita
      Bom dia pessoal!
      Vocês também estão programando em primeira pessoa? Recentemente escrevi este artigo e gostaria de compartilhar a ideia com vocês.
      Pare de programar em primeira pessoa!
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.