Categorias
Programação Sem categoria

E os posts?

Calma, tudo ao seu tempo.

Já falei aqui que quero postar sobre Orientação a Objetos, sobre os livros que comprei recentemente, sobre o Joomla! e claro, continuar os artigos sobre validação ( afinal, temos de concluir o que iniciamos, não é? ). Meu próximo post será a continuação dos posts sobre validação. Não, eu ainda não o escrevi, mas o farei ainda hoje, mais tardar amanhã. Mas apesar de não ter escrito, já sei o que farei.

Em seguida, devo escrever um post sobre o Joomla! ( estou fazendo aquele componente que comentei anteriormente ), e está sendo uma experiência legal.

Neste meio tempo, provavelmente haverão alguns posts menos nerds, ou geek como preferirem. Minha vida acadêmica está voltando ao normal e com ela minhas responsabilidades com o Movimento Estudantil ( não, eu não fiquei a toa minhas férias e deixei tudo parado, não totalmente ). E com maior vivencia do assunto, as idéias, conflitos e reflexões vão “aflorando” e pretendo usar este espaço como válvula de escape, afinal, ninguém é de ferro – eu muito menos.

Está chegando a era da filosofia nerd neste blog ( não precisam se assustar, não serei tão incisivo, não no começo ), mas o mundo nerd não perderá mais um espaço, continuarei falando MUITO sobre programação, tecnologia ( que não comentei ainda ) e afins.

Até breve.

Categorias
ActionScript Joomla! Programação

Novidades…

Tirei um tempinho para falar de uma coisa que acabei de ver. Como alguns já sabem, sou fã do ActionScript, ou seja, do Adobe Flash ( antes Macromedia Flash ), acho esta linguagem de programação extremamente ágil e simpática. Foi uma das primeiras linguagens de programação na qual tive contato ( na verdade, quando à conheci, ainda não era considerada uma linhagem de programação, mais ou menos na época do Flash 4 ).

No começo de meus estudos, utilizada duas fontes de conhecimento: Ponto Flash e FlashMasters . Utilizava muito o primeiro, mas devido a falta de manutenção, acabei deixando de acessar. O segundo utilizo até hoje. Mas utilizo a seção que acho a mais importante deste portal, o Fórum.

O Fórum do FlashMasters é considerado o maior fórum do assunto em lingua portuguesa, e possui muita gente de fora do país. Eu mesmo já ajudei e fui ajudado por pessoas na França e em Portugal.

Acontece que o pessoal responsável pelo portal fez uma grande mudança na estrutura dele, na verdade, mudaram tudo. Adivinhem qual o sistema que agora gerencia o conteúdo do FlashMasters? Sim, acertou quem falou Joomla! ( devo estar obcecado por este CMS, hehehe ). Parabéns a todos que fizeram as alterações, ficou excelente, tanto visualmente como em funcionalidades ( segundo o William – diretor e criador do portal -, eles tiveram ajuda da comunidade Joomla Clube ).

Este novo portal até me deu vontade de voltar a participar do Fórum, e agora também, do portal ( é possível inserir conteúdo diretamente no portal, ótima idéia ). Dentre em breve estarei colocando lá umas classes que fiz em AS3 ( ActionScript 3 ).

Caso queiram me encontrar por lá, meu usuário é “Dotti”.

—- Atualizado —-

Ingratidão, escrevi na pressa e acabei esquecendo de falar do local onde mais aprendi: IRC . Sim, o bom e velho IRC ( que alguns chamam de mIRC ). Eu utilizava a rede Brasnet. Entrava nos canais #Flash , #PHP e alguns outros menos nerds ( #Porkaria, #Bingola, #Meleca e #Oakley ). Bons tempos.

No IRC conheci alguns dos usuários e agora administradores do FlashMasters. Gente que me ajudou muito e que devo certa gratidão. Daria até para citar alguns, mas acho que não seria justo com outros que também me ajudaram muito. De qualquer forma, obrigado a todos os velhos amigos do #Flash e agora do FlashMasters.

— Atualizado Novamente —

Links corrigidos, obrigado Gelinho.

Categorias
Desenvolvimento Web Joomla! Programação

Sem assunto – parte 3

“Puta mundo injusto meu!” by Boça.

É como disse o sábio Boça.
Passei meu sábado e meu domingo trabalhando.
Um final de semana inteiro na frente do PC. Se fosse para outro próposito até que não teria sido tão cansativo.

Como comentei em um post anterior, estou estudando o Joomla! 1.5 e alguns componentes para ele ( JEvents, Community Builder, Hydra, uddeIM ). Estava olhando o dotProject, mas ele não atenderia as minhas necessidades facilmente, então parti somente para o Joomla!.

Incrível a facilidade de se utilizar este CMS. Seu código está muito organizado e legível. Em pouco tempo dá para se entender bem o funcionamento de tudo.

Estou enfrentando alguns problemas, uns por parte do próprio Joomla! outros por parte de alguns módulos/componentes. O hydra ( componente para administração de projetos ) não me permite acesso pelo FrontEnd, algo essencial para meu propósito, provavelmente o erro é meu, mas não consegui achar nada a respeito.
O JEvents está com vários erros. Não consegue gravar o arquivo de configurações, exibe um calendário repetidamente no frontend. Além de não permitir alterações nas configurações ( sempre ocorre um erro apontando para uma página inexistente ).
O uddeIM funciona até. O único problema são seus textos e menus, que eu não consigo achar os arquivos que o geram para alterar. Ele está gerando uma saída html errada – não coloca àspas em um valor de atributo html. Também não consigo achar onde devo fazer a tradução dos termos.
O Community Builder está quase 100%. Inclusive estou fazendo a tradução do arquvo de internacionalização para o português do Brasil. Assim que terminar, estarei disponibilizando aqui e em alguma comunidade Joomla!. Meu único problema com ele é não descobrir onde é gerado o menu que fica acima do perfil dos usuários, para retirar o primeiro botão ( que direciona para a página do Community Builder ).

Mas até que está bem, levando em conta que nunca havia usado nenhum destes sistemas e que meu está com o WAMP bem meia boca.

Se alguém tiver idéia de como arrumar estes problemas, ou souber o que estou fazendo de errado, deixe um comentário ou envie-me um email: cauanc [em] gmail [ponto] com

Categorias
Joomla! Livros PHP Programação

Sem assunto – parte 2

Diário de bordo.
Data estrelar: 3, 4 do 3 do 2 do 1.
Pavilhão nove
Quadrante treze…

Música: “Jesus Negão”, autor: desconhecido.

Mais um dia está prestes a se encerrar.
Hoje, passei boa parte do dia estudando sistemas em PHP.

Primeiro perdi minha manhã inteira configurando WAMP ( Windows XP SP2 + Apache 2.2.6 + MySQL 5.0.45 + PHP 5.2.5 ).
Instalei tudo da maneira mais simples possível ( utilizando os executáveis compilados, inclusive do PHP ), mas mesmo assim apareceu um erro. Na verdade dois erros, mas um foi, de certa forma, burrice minha – havia esquecido de copiar a dll libmysql para a pasta do Windows. Uma coisa tão besta, que a gente faz dezenas de vezes na vida, e eu consigo cometer algum erro toda vez, nunca configurei o WAMP de primeira.

O segundo erro é um problema com alguma extensão do PHP. O apache travava toda vez que tentava executar um script PHP. Algo muito estranho. Procurei no google pelo crash e só encontrei suposições. Uma delas era de que a extensão com problema era a php_mysql.dll ou php_mysqli.dll . Desativei todas as extensões do PHP e fui reativando uma a uma para descobrir qual estava causando o crash. Até que havia ativado as extensões php_mysql e php_mysqli sem que o apache travasse. Uffa, pelos menos o essencial eu tinha.
Acabou que não descobri a extensão que causava o crash, apenas que não era nem a GD, nem MySQL(i), nem PDO. Outra hora tento descobrir. Aliás, vi em um fórum na web, um cara com problema na extensão PDO para mysql, não respondi no fórum porque necessitava cadastro, e o tópico parecia bem antigo, mas o problema dele era a falta da extensão PDO ( a extensão genéria PDO, ela tem que ser carregada para que se carregue as extensões específicas, como a do mysql ).

Enquanto cedia o computador para outras pessoas, retomei a leitura do livro que chegou recentemente.
Estou gostando da leitura. O 1º capitulo aborda várias funções do PHP. O 2º capitulo já explica Orientação Objetos. De modo geral, tudo é muito bem explanado e possui exemplos.
Sinceramente, só não gostei muito da parte que aborda o Polimorfismo. Achei o assunto meio vago, talvez pela falta de suporte do PHP.

Falando em Orientação a Objetos, estou com umas idéias em mente. Penso em escrever um pouco sobre o tema aqui, não vou perguntar a opinião de vocês por que sei que não existe o “vocês”, hehehe. Mas gostaria de estar escrevendo sobre Programação Orientada Objetos, de forma bem genérica, usando exemplos em várias linguagens – C++, Java, PHP, ActionScript. Quem sabe nesta próxima semana não me inspiro.

A, esqueci de dizer quais sistemas em PHP eu estudei durante a manhã, foram eles: Joomla! 1.5 e dotProject . Sistemas excelentes, sob licença GPL. Recomendados. Se você programa, ou é fluente em Inglês-Português, pode ajudar estes projetos, um grande aprendizado ( é, eu tenho que fazer isso também ).

Até.

Categorias
Desenvolvimento Web PHP Programação

Validação de dados em PHP5 – Parte 2

Continuando a série de artigos sobre validação de dados ( veja a primeira parte ) com PHP5.

Nota: usarei “cliente” para me referir a um usuário do sistema, ou mesmo outro sistema que interaja conosco. Usarei também ER para designar expressão regular, que é o assunto base deste post.

Anteriormente, havíamos abordado uma validação mais geral, onde tínhamos de aceitar vários tipos de dados.

Agora, vamos abordar uma situação onde esperamos um dado específico vindo do cliente – usarei “cliente” para referir tanto ao usuário do sistema quanto outros sistemas – por exemplo, em um campo de formulário, onde esperamos um nome ou um email.

Um dos recursos mais eficientes em se tratando de validação é o uso de expressões regulares. E é com isto que iremos trabalhar.

Vamos a uma definição:

“Uma expressão regular, na Informática, define um padrão a ser usado para procurar ou substituir palavras ou grupos de palavras. É um meio preciso de se fazer buscas de determinadas porções de texto.” Fonte: Wikipédia.

Então uma expressão regular é um padrão. Por isso não podemos utilizar uma expressão regular para validar algo que desconhecemos, porque seria muito difícil ou mesmo impossível encontrar um padrão para tudo.

Não pretendo explicar os fundamentos de uma expressão regular, se desejar alguma referência, recomendo o site: http://guia-er.sourceforge.net

Como podemos utilizar uma expressão regular para validar um campo de um formulário? Precisamos de uma função do PHP que faça esta verificação para a gente, uma função que compare nossa expressão regular com o valor a ser testado.

O PHP oferece algumas funções para isso, vejamos duas delas:

 

ereg( string $expressão , string $variável [, array $registros ] )

 

Retorna TRUE se $variável “bater” com $expressão, e FALSE se a expressão não casar ou se acontecer algum erro. referência

//nossa ER, um padrão para CEP
$cepER = ‘^[0-9]{5}\-[0-9]{3}$’;
//vamos supor que temos a variável $_POST[‘cep’] vinda de um formulário

//fazemos então a verificação
if( ereg( $cepER, $_POST[‘cep’] ) )
echo “Isso parece um CEP válido”;
else
echo “Isso não é um CEP válido”;

Por que não podemos afirmar se o CEP está correto? Simplesmente porque com a ER analisamos apenas a forma da variável, ou seja, se ela tem o mesmo número de caracteres, se são do mesmo tipo e estão nas mesmas posições. Para afirmarmos com segurança que o CEP é válido, teríamos de verificar se o valor está cadastrado nos Correios ou em alguma outra fonte segura. Mas isso foge ao nosso escopo.

Essa função ereg permite fazer a buscar por um padrão em uma string utilizando padrão POSIX, mas o PHP fornece outra função para a mesma tarefa, com desempenho melhor, e baseado no padrão PCRE ( compatível com PERL ). Esta função é a preg_match.

preg_match( string $expressão , string $variável [, array &$matches [, int $flags [, int $offset ]]] )

Retorna 1 se a $variável “bater” com a $expressão, e 0 caso contrário. referência.

Vamos ver o uso do preg_match na mesma situação do exemplo anterior:

//nossa ER, um padrão para CEP
$cepER = ‘/[0-9]{5}\-[0-9]{3}/’;

//vamos supor que temos a variável $_POST[‘cep’] vinda de um formulário
//fazemos então a verificação, poderíamos omitir o “== 1”, já que o PHP converte 0 e 1 para false e true respectivamente
if( preg_match ( $cepER, $_POST[‘cep’] ) == 1 )
echo “Isso parece um CEP válido”;
else
echo “Isso não é um CEP válido”;

Notem a diferença na nossa ER. Mudamos os caracteres de inicio e final, isto acontece por conta da diferença entre os padrões que as funções utilizam.

O artigo já está muito grande, continuarei a falar sobre ER nos próximos artigos. Vamos ver como criar ER para validar telefone, email e por último CPF ( que incluiremos outro teste de validação além da ER ).

Uma última dica, utilizem ER juntamente com o método do artigo anterior, para aumentar a segurança de seu sistema ( pense em outras formas para isso também ).

Por enquanto é só.

Não esqueçam de validar tudo.

Categorias
PHP Programação

Validação de dados em PHP5 – Parte 1

Olá a todos, nesta série de artigos ( espero eu ) estarei dando algumas dicas de como tratar valores com o PHP.

Uma preocupação cada vez maior ao se criar sistemas é a segurança, e um das áreas em que devemos ter maior preocupação é na hora de usar informações provenientes de agentes externos ( pessoas ou outros sistemas ).

Temos de levar sempre em consideração que nunca poderemos prever todas as maneiras que um usuário ( ou mesmo outro sistema ) utiliza nosso código. Os usuários sempre arrumam uma forma “inovadora” de usar nossos sistemas, podendo causar falhas críticas no mesmo. Então, sempre que for criar um sistema que interaja com alguém, proteja-se de todas as maneiras possíveis, e dependa o mínimo possível de fatores externos ( como boa vontade e conhecimento do usuário, ou que o sistema alheio não falhe ).

A palavra de ordem é: “Valide TUDO”. Sim, qualquer coisa que venha de fora de seu sistema tem de passar por validação. Seja um valor utilizado para atribuição à variável, seja para uma consulta à um banco de dados, tudo deve ser validado.

Nesta primeira parte, falarei sobre o tratamento de variáveis vindas do cliente ( usuário ou sistema ) pelos arrays superglobais $_POST e $_GET, e que não sabemos ao certo o que esperar ( ou seja, podemos utilizar este método para receber um nome, telefone, email, data ou qualquer outro dado suportado pelo PHP ).

Abaixo segue um método que utilizo para tratar estes valores:

public function __set( &$atributo, $valor )
{
//Testa se existe algum valor a ser utilizado na atribuição
if( !empty($valor) )
{
//Faz a conversão de tipo, como o PHP tem uma tipação fraca ( ou seja, deixa você atribuir uma String em um váriavel que tinha um Número ), isto pode ajudar.
settype( $valor, gettype($atributo) );

//Verifico se magic_quotes_gpc está ativo na configuração do PHP, isto será removido no PHP 6( veja sobre isto )
if (!get_magic_quotes_gpc())
//Adiciono caracter de scape em tudo o que possa ser perigoso ( veja mais sobre isso )
$valor = addslashes($valor);
//Faço a atribuição normalmente.
$atributo = $valor;
}
}

Este é um método que pode ser incluído em qualquer classe. Ele possui um nome especial “__set”, que para o PHP, indica que ele será usado toda vez que for feita uma atribuição de valor para um atributo da classe ( posso falar mais sobre os métodos especiais do PHP5 em um próximo post ).

Por exemplo, quando utilizarmos o comando abaixo, atribuindo o valor nome do array $_GET ao atributo nome de nossa classe:

$classe->nome = $_GET[‘nome’];

O PHP interpretará como:

$classe->__set( nome, $_GET[‘nome’] );

 

e fará todas as verificações que contém no método.

Podemos utilizar outras funções de validação em nosso método, mas temos de tomar cuidado para não restringir demais os dados, lembrando sempre que esta validação será usada TODA vez que fizermos uma atribuição.

Poderíamos por exemplo refinar nossa validação utilizando expressões regulares, mas isso provavelmente não lhe traria bons resultados, pois uma expressão regular define uma regra que deve ser seguida, e no nosso caso, nós não sabemos o que esperar, então como poderia impor uma regra? Perderíamos muitos dados corretos utilizando uma expressão regular ( a menos que ela fosse pouco restritiva, o que faria perder sua função ).

 

Por enquanto é isto.

Espero ter ajudado, e até a próxima.