Blog de David Rodriguez

Internet, tecnologia, programacion, SEO

Argument list too long usando rm en linux

noviembre 14th, 2011 by David Rodriguez

Si queremos borrar un número elevado de archivos dentro de un directorio en linux, lo solemos hacer:

> rm -rf ./*

Esto es un problema si el número es demasiado elevado, con lo que la consola linux te devuelve el error Argument list too long

Para solucionar esto, podemos utilizar el comando find unido con el comando rm

> find . -name ‘*.html’ | xargs rm

De esta forma ya tenemos solucionado el problema y podemos borrar un número elevado de archivos dentro de un directorio.

Category: Programacion, servidores | 1 Comment »

Encuestas online gratis con PHP

abril 30th, 2010 by David Rodriguez

Muchas veces necesitamos realizar algún tipo de encuesta en la web y no sabemos que programas gratuitos utilizar o cual es el mejor para estas cosas.

Se puede ir a una empresa de encuestas online, que tienen alguna versión gratuita, pero cuyo fin, siempre va a ser que pruebes el servicio y finalmente pagues por él. Podeis probar con e-encuesta.com y encuestafacil.com

Si lo que se desea es poner una pequeña encuesta en la web que una simple pregunta … lo mas sencillo es utilizar el script Simple PHP Poll.

Y si finalmente, lo que queremos es una herramienta completa de gestión de encuestas, con todas configuraciones posibles, idiomas, tipos de pregunta, estadisticas, etc, la mejor opción es Lime Survey, que es una herramienta gratis en PHP y MySql. Facilmente instalable y con un interface muy intuitivo y usable(no hace falta hacer ningún curso para utilizarlo)

No perdais tiempo buscando otras opciones, ya que esta, de momento, es la mejor.

Category: Internet, Programacion | No Comments »

Actualizacion modulo envio de correos en de PHPMimeMail a RMail

abril 8th, 2010 by David Rodriguez

Hemos venido utilizando desde hace muchos años el modulo PHPMimeMail para el envio de correos en PHP, es una clase que funciona muy bien y estaba muy implementado.

El problema es que se está quedando obsoleta. El mismo creador, ha creado RMail, otro modulo de envio que funciona para PHP5 y que hemos comprobado con nuestros desarrollos web, que mejora en un 70% los tiempos de envio.

El proceso de actualización es muy sencillo ya que los metodos utilizados en ambos módulos son similares.

Method Description
Constructor Doesn’t take any arguments. Not much to say I guess.
setCRLF(string $crlf) Sets the CRLF line ending type to use. You should not use this unless you’re sure you know what you’re doing, as the code will correctly (most of the time) determine which type to use by itself.
setSMTPParams(string $host,
int $port,
string $helo,
bool $auth,
string $user,
string $pass)
Set SMTP parameters when using SMTP to send the email. All optional, though not specifying any would be pointless… Pretty self explanatory really – hostname to connect to, port to connect to, text to send as part of the HELO command, whether to use SMTP authentication, and if so the username and password to use.
setSendmailPath(string $path) Sets the path to use when using sendmail method of sending the email. This should be the full path to the sendmail binary on your system, along with any command line parameters. Defaults to “/usr/lib/sendmail -ti”.
setTextEncoding(object $encoding) Sets the encoding to use (if any) on the plain text part of the email. The argument should be one of the encoding objects, ie Base64Encoding, QPrintEncoding, SevenBitEncoding or EightBitEncoding. Bit pants about the 7bit/8bit names, but identifiers in PHP can’t start with a number. Tits.
setHTMLEncoding(object $encoding) Sets the encoding to use (if any) on the HTML part of the email. The argument should be one of the encoding objects, ie Base64Encoding, QPrintEncoding, SevenBitEncoding or EightBitEncoding.
setTextCharset(string $charset) Sets the characterset to use on the plain text portion of the email. Defaults to “ISO-8859-1″.
setHTMLCharset(string $charset) Sets the characterset to use on the plain text portion of the email. Defaults to “ISO-8859-1″.
setHeadCharset(string $charset) Sets the characterset to use on the headers of the email. Defaults to “ISO-8859-1″.
setTextWrap(int $count) Set the point at which text is wrapped in the email. Defaults to 998, which is a limit imposed by the SMTP standard.
setHeader(string $name, string $value) Sets a header of the email. First argument if the name of the email, second is the value.
setSubject(string $subject) Sets the subject of the email.
setFrom(string $from) Sets the From: header of the email.
setPriority(mixed $priority) Sets the priority of the email. Defaults to “normal”. Argument can be either “high”, “normal” or “low”, or 1, 3 or 5 respectively.
setReturnPath(string $return_path) Sets the Return-Path: of the email. This is the address to which bounces will be sent if the email fails to be delivered.
setCc(string $cc) Sets the Cc: header of the email. The email will be delivered to these addresses as well as those specified in the send() method.
setBcc(string $bcc) Sets the Bcc: header of the email. The email will be delivered to these addresses as well as those specified in the send() method. However, the Bcc: header will be removed from email before it is sent, so those addresses in the To: and Cc: headers will not know it has also been sent to these addresses. Hence, “Blind” Carbon Copy.
setText(string $text) Sets the text part of the email.
setHTML(string $html[, string $images_dir]) Sets the HTML part of the email. The optional second argument specifies a directory where the code should look for images referenced by the HTML. If found, these images will automatically be embedded into the email.
addEmbeddedImage(object $embeddedImage) Adds an embeddded image to the email. The argument should be on of the fileEmbeddedImage or stringEmbeddedImage objects, depending on the source of the image.
addAttachment(object $attachment) Adds an attachment to the email. The argument should be one of the fileAttachment or stringAttachment objects, depending on the source of the attachment.
send(array $recipients[, string $type]) Sends the email. The first argument is an array of recipients to whom the email will be sent to. The second is how to send the email. This can be one of “mail”, “sendmail” or “smtp”, and defaults to “mail”.
getRFC822(array $recipients[, string $type]) This function first of all builds the email, and then returns it in text format. This is useful if you need to attach the email to another email. This could be done like so: $mail_2->addAttachment(new stringAttachment($mail_1->getRFC822(array(‘richard@example.com’)), ‘message/rfc822′)) The first argument is an array of recipients to place in the To: header, whilst the second, optional, $type argument should be the same as that you intend to use eventually for the send() method. This is to ensure the correct line endings are used.

Category: Internet, Programacion | No Comments »

redireccionar a un idioma segun el pais del usuario

abril 5th, 2010 by David Rodriguez

Para redireccionar a un usuario según sea su pais de procedencia (bueno .. ya sabemos que los servidores desde donde se conectan los usuarios no son 100% fiables .. pero es la unica forma que tenemos de saberlo), utilizamos el api de hostip.info y cargamos el xml que nos dan.

Para ello hemos definido la siguiente función:

function getPaisProcedencia(){
$salida = ”;

$IPADDRESS = $_SERVER["REMOTE_ADDR"];

$archivo_xml = “http://api.hostip.info/get_xml.php?ip=”.$IPADDRESS .”";
$procedencia_xml = get_url_contents ($archivo_xml);

if (empty($procedencia_xml)){
$salida = ”;
}else{
preg_match_all(“|<Hostip>(.*)</Hostip>|sU”, $procedencia_xml, $items);
$lista_nodos = array();
foreach ($items[1] as $key => $item)
{
//preg_match(“|<gml:name>(.*)</gml:name>|s”, $item, $mi_lugar);
//preg_match(“|<countryName>(.*)</countryName>|s”, $item, $mi_pais);
preg_match(“|<countryAbbrev>(.*)</countryAbbrev>|s”, $item, $mi_sigla);
$salida = $mi_sigla[1];
}
$procedencia_xml = “”;
}

return  $salida;
}

En esta función hemos utilizado la función get_url_contents descrita en un post anterior sobre optimizacion de file_get_contents en php.

Podemos sacar mucha información del xml de este API http://api.hostip.info/get_xml.php?ip=200.147.3.156

<HostipLookupResultSet version=”1.0.1″ xsi:noNamespaceSchemaLocation=”http://www.hostip.info/api/hostip-1.0.1.xsd”>
<gml:description>This is the Hostip Lookup Service</gml:description>
<gml:name>hostip</gml:name>

<gml:boundedBy>
<gml:Null>inapplicable</gml:Null>
</gml:boundedBy>

<gml:featureMember>

<Hostip>
<ip>200.147.3.156</ip>
<gml:name>(Unknown city)</gml:name>
<countryName>BRAZIL</countryName>
<countryAbbrev>BR</countryAbbrev>
<!– Co-ordinates are unavailable –>
</Hostip>
</gml:featureMember>
</HostipLookupResultSet>

El nodo sobre el que hemos realizado las comprobaciones es countryAbbrev aunque se podría utilizar countryName, aunque siempre vamos a usar menos recursos si comparamos abreviaturas que cadenas de nombres más largas.

Ojo, esta función no es recomendable utilizarla cada vez que tenemos una hit .. ya que ralentizaría nuestra maquina de manera injustificada. Asi que lo que recomiendo es utilizarla unicamente en la primera visita a nuestra web. Esto lo podemos controlar con sesiones, cookies, referer, etc … nosotros hemos utilizado el referer del usurio aunque otras opciones serían igualmente válidas.

Category: Internet, Programacion | 3 Comments »

optimizar tiempos de file-get-contents en php

abril 5th, 2010 by David Rodriguez

A veces tenemos que cargar xml o contenido externo a nuestra web.

En php, tenemos la función file-get-contents para leer un fichero y devolver un string. En ese caso, podemos tener diferencia de tiempos de carga entre ejecutar un xml en el navegador .. y cargar ese xml en un string.

Esto puede ser debido a las politicas de seguridad de los servidores donde cargamos la información.

Para reducir estos tiempos y que nuestra web no se ralentice, es mejor cambiar esa función por esta otra que nos definimos nosotros a través del método curl.

function get_url_contents($url){
$crl = curl_init();
$timeout = 25;
curl_setopt ($crl, CURLOPT_URL,$url);
curl_setopt ($crl, CURLOPT_RETURNTRANSFER, 1);
curl_setopt ($crl, CURLOPT_CONNECTTIMEOUT, $timeout);
$ret = curl_exec($crl);
curl_close($crl);
return $ret;
}

Tenemos mejoras en tiempos de un 75% menores en la carga.

Category: Internet, Programacion | 1 Comment »

Problemas con tildes y acentos en el Subject utilizando HtmlMimeMail

marzo 29th, 2010 by David Rodriguez

Encontramos un bug en la clase HtmlMimeMail, donde si utilizabas dos palabras seguidas con tildes en el asunto del mensaje a enviar, el programa juntaba ambas palabras.

Esto pasaba por la codificación de caracteres que se puede ver con este ejemplo:

Asunto: … Carné de Especialista en Instalación de Tuberías Plásticas

La codificación de caracteres enviada era la siguiente:

Subject: =?ISO-8859-1?Q?Carn=E9?= de Especialista en =?ISO-8859-1?Q?Instalaci=F3n?= de =?ISO-8859-1?Q?Tuber=EDas?= =?ISO-8859-1?Q?Pl=E1sticas?=

Donde podemos observar que el espacio entre esas palabras no lo codificaba bien.

Para solucionar este problema, simplemente hay que hacer los siguientes cambios en la función _encodeHeader de la clase htmlMimeMail:

function _encodeHeader($input, $charset = ‘ISO-8859-1′) {
preg_match_all(‘/(\w*[\x80-\xFF]+\w*)/’, $input, $matches);
$codex = 0 ;
foreach ($matches[1] as $value) {
$codex = 1;
$replacement = preg_replace(‘/([\x80-\xFF])/e’, ‘”=” . strtoupper(dechex(ord(“\1″)))’, $value);
$input = str_replace($value, ‘=?’ . $charset . ‘?Q?’ . $replacement . ‘?=’, $input);
}
if ($codex==1)
$input = str_replace(‘ ‘,’=?’ . $charset .  ‘?Q?’ . ‘=20′ . ‘?=’, $input);
return $input;
}

De esta forma solucionamos el problema. Hemos encontrado la solución en esta pagina.

Category: Internet, Programacion | No Comments »

qmail ejecutar un php al recibir un email

mayo 22nd, 2009 by David Rodriguez

Si tienes qmail instalado como MTA, y quieres realizar alguna acción cuando recibas un correo, como por ejemplo ejecutar un php para filtrar spam, controlar devoluciones de correo, redirecciones, autorespuestas, etc puedes realizar lo que nos comenta Osus en su blog.

Si os digo la verdad, a mi no me funcionaba lo que el propone. Con lo cual, tuve que hacer unas modificaciones para encontrar mi solución, la cual os pongo aquí.

1.- Modificar el archivo .qmail que te genera en la carpeta del nombre del usuario. en mi caso se encuentra en /var/qmail/mailnames/dominio.com/nombredeusuario/.qmail

2.- Añadir la siguiente linea

| php -f paginaaejecutar.php > log.txt

con esto, ejecutamos ese fichero php cuando nos llega un correo y grabamos lo que nos devuelve ese php en un fichero para poder tracear el proceso.

3.- la pagina php debe tener algo parecido a esto:

CODIGO PHP:

$email = file_get_contents(“php://stdin”);

$email = str_replace(array(“\n”, “\r”), ” “, $email);

print $email;
FIN CODIGO PHP

De esta forma, al llegar el correo, lo tratamos que esté en una linea, y podemos tratar el texto de ese correo.

Es impresionante las muchas cosas que se pueden hacer con qmail .. y la poca ayuda o personas que ponen sus conocimientos sobre ejemplos para realizarlas.

Muchas gracias a mi compañero Jaime, que es un monstruo y me ayuda con todos estos cabezazos contra el ordenador.

Category: Internet, Programacion | 1 Comment »