Dica rápida: PHP + BYTEA

Fala galera! Estava aqui tentando exibir imagens armazenadas em um campo bytea do PostgreSQL e apanhei feito mala velha usando o par de funções pg_escape_bytea e pg_unescape_bytea.

Consegui achar a solução em um comentário no manual do PHP: “To prevent any problems with encoding you could use hexadecimal or base64 input to save and retrieve data to the database”

Usei base64_encode/base64_decode e tudo funcionou perfeitamente. Então, se você está tentando usar pg_escape_bytea($content) e pg_unescape_bytea($content) mude para base64_encode($content) para inserir no banco e base64_decode($content) para exibir no browser.

Valeu Mike-RaWare!

Para quem quiser ver o post: http://php.net/manual/en/function.pg-escape-bytea.php

Gerando documentos PDF com FPDF – Parte 01

Olá pessoal!

Hoje vou iniciar uma série de postagens sobre como gerar documentos em PDF usando a classe FPDF.
Por agora vou mostrar como fazer a configuração básica e criar um exemplo funcional. Go, Go, Go!!

Você pode baixar o FPDF no site oficial do projeto: http://www.fpdf.org/. Para começar a criar seus arquivos em PDF, basta copiar os arquivos para seu servidor web. Certifique-se de que os arquivos estão no seu include path.

Vamos então à um exemplo prático:

<?php

define(‘FPDF_FONTPATH’,’font/’);

require(‘fpdf_dir/fpdf.php’);

$pdf = &new FPDF(“L”,”mm”,”A4″);
$pdf->Open();
$pdf->AddPage();
$pdf->SetFont(‘Arial’,’B’, 14);
$pdf->Text(40,20,’Título do Relatório’);
$pdf->SetLineWidth(0.7);
$pdf->Line(40,22,200,22);
$pdf->SetXY(40,26);
$pdf->SetFont(”,”,12);
$pdf->Cell(30,5,’Modelo’,0,0,’C’,0);
$pdf->Cell(30,5,’Fabricante’,0,0,’C’,0);
$pdf->Output();
?>

Explicando o código:

Define o caminho para as fonts usadas pelo FPDF. Em outro post irei explicar como criar suas próprias fonts.
define(‘FPDF_FONTPATH’,’font/’);

Inclui as definições da classe FPDF no script PHP.
require(‘fpdf_dir/fpdf.php’);

Cria uma nova instância da classe FPDF para um documento com orientação paisagem (Landscape), com medidas em milímetros e no formato A4. Feito isso, o documento é iniciado.
$pdf = &new FPDF(“L”,”mm”,”A4″);

$pdf->Open();

Adiciona uma nova página ao documento.
$pdf->AddPage();

Define a font do documento como Arial, tamanho 14 em negrito. Essa configuração será válida até que SetFont() seja chamado novamente.
$pdf->SetFont(‘Arial’,’B’, 14);

Escreve o texto “Título do Relatório” na linha 40 (eixo x) e coluna 20 (eixo y)
$pdf->Text(40,20,’Título do Relatório’);

Cria uma linha horizontal logo abaixo do texto definido anteriormente.
$pdf->SetLineWidth(0.7);
$pdf->Line(40,22,200,22);

Aponta o cursor para a posição (x,y) definida em SetXY(). Retira o negrito da font e altera o tamanho para 12.
$pdf->SetXY(40,26);
$pdf->SetFont(”,”,12);

Cria duas células com as mesmas dimensões ( 30mm de largura e 5mm de altura ), sem borda, apontando o cursor para o final da linha, após a célula criada, com o texto alinhado no centro e com prenchimento transparente.
$pdf->Cell(30,5,’Modelo’,0,0,’C’,0);
$pdf->Cell(30,5,’Fabricante’,0,0,’C’,0);

Finalmente, renderiza o seu documento \o/.
$pdf->Output();

Encoding

Caso você tenha problemas com acentuação na saída do documento, use a função iconv do PHP. Nela você irá converter um texto de um charset de origem para outro de destino. Use desta forma:
$pdf->Text(40,20,iconv(‘utf-8′,’iso-8859-1′,’Título do Relatório’));

É isso ai, espero que tenham gostado. Um abraço e até o próximo post.