rss
twitter
  •  

Un buen desayuno con Zend

| Posted in General |

1

Está mañana a las 8:30 ha tocado el cartero a mi puerta, nada del otro mundo considerando que nos llegan todo tipo de papeles varias veces por semana.

Pero en esta ocasión trajo algo muy particular… algo que procedía de Cupertino, California.

Zend

Ya había visto algunas fotos de como sería el famoso certificado, de hecho ya estaba consciente de que el diseño lo habían “modernizado”, lo que no imaginaba era el momento en que yo mismo tendría la oportunidad de hacer lo mismo :-)

ZCE Certificado

Ahora si puedo decir que la arepita con queso e’ mano que me estaba comiendo, sabe ahora mucho mejor !

¿Qué más puedo decir?, pues sólo aconsejar a quienes me leen, que si tienen oportunidad de certificarse, HÁGALO!

Manifiesto por una Red Neutral

| Posted in General |

0

Los ciudadanos y las empresas usuarias de Internet adheridas a este texto manifestamos:

1. Que Internet es una Red Neutral por diseño, desde su creación hasta su actual implementación, en la que la información fluye de manera libre, sin discriminación alguna en función de origen, destino, protocolo o contenido.

2. Que las empresas, emprendedores y usuarios de Internet han podido crear servicios y productos en esa Red Neutral sin necesidad de autorizaciones ni acuerdos previos, dando lugar a una barrera de entrada prácticamente inexistente que ha permitido la explosión creativa, de innovación y de servicios que define el estado de la red actual.

3. Que todos los usuarios, emprendedores y empresas de Internet han podido definir y ofrecer sus servicios en condiciones de igualdad llevando el concepto de la libre competencia hasta extremos nunca antes conocidos.

4. Que Internet es el vehículo de libre expresión, libre información y desarrollo social más importante con el que cuentan ciudadanos y empresas. Su naturaleza no debe ser puesta en riesgo bajo ningún concepto.

5. Que para posibilitar esa Red Neutral las operadoras deben transportar paquetes de datos de manera neutral sin erigirse en “aduaneros” del tráfico y sin favorecer o perjudicar a unos contenidos por encima de otros.

6. Que la gestión del tráfico en situaciones puntuales y excepcionales de saturación de las redes debe acometerse de forma transparente, de acuerdo a criterios homogéneos de interés público y no discriminatorios ni comerciales.

7. Que dicha restricción excepcional del tráfico por parte de las operadoras no puede convertirse en una alternativa sostenida a la inversión en redes.

8. Que dicha Red Neutral se ve amenazada por operadoras interesadas en llegar a acuerdos comerciales por los que se privilegie o degrade el contenido según su relación comercial con la operadora.

9. Que algunos operadores del mercado quieren “redefinir” la Red Neutral para manejarla de acuerdo con sus intereses, y esa pretensión debe ser evitada; la definición de las reglas fundamentales del funcionamiento de Internet debe basarse en el interés de quienes la usan, no de quienes la proveen.

10. Que la respuesta ante esta amenaza para la red no puede ser la inacción: no hacer nada equivale a permitir que intereses privados puedan de facto llevar a cabo prácticas que afectan a las libertades fundamentales de los ciudadanos y la capacidad de las empresas para competir en igualdad de condiciones.

11. Que es preciso y urgente instar al Gobierno a proteger de manera clara e inequívoca la Red Neutral, con el fin de proteger el valor de Internet de cara al desarrollo de una economía más productiva, moderna, eficiente y libre de injerencias e intromisiones indebidas. Para ello es preciso que cualquier moción que se apruebe vincule de manera indisoluble la definición de Red Neutral en el contenido de la futura ley que se promueve, y no condicione su aplicación a cuestiones que poco tienen que ver con ésta.

La Red Neutral es un concepto claro y definido en el ámbito académico, donde no suscita debate: los ciudadanos y las empresas tienen derecho a que el tráfico de datos recibido o generado no sea manipulado, tergiversado, impedido, desviado, priorizado o retrasado en función del tipo de contenido, del protocolo o aplicación utilizado, del origen o destino de la comunicación ni de cualquier otra consideración ajena a la de su propia voluntad. Ese tráfico se tratará como una comunicación privada y exclusivamente bajo mandato judicial podrá ser espiado, trazado, archivado o analizado en su contenido, como correspondencia privada que es en realidad.

Europa, y España en particular, se encuentran en medio de una crisis económica tan importante que obligará al cambio radical de su modelo productivo, y a un mejor aprovechamiento de la creatividad de sus ciudadanos. La Red Neutral es crucial a la hora de preservar un ecosistema que favorezca la competencia e innovación para la creación de los innumerables productos y servicios que quedan por inventar y descubrir. La capacidad de trabajar en red, de manera colaborativa, y en mercados conectados, afectará a todos los sectores y todas las empresas de nuestro país, lo que convierte a Internet en un factor clave actual y futuro en nuestro desarrollo económico y social, determinando en gran medida el nivel de competitividad del país. De ahí nuestra profunda preocupación por la preservación de la Red Neutral. Por eso instamos con urgencia al Gobierno español a ser proactivo en el contexto europeo y a legislar de manera clara e inequívoca en ese sentido.

Si te sientes representado por este manifiesto te pedimos encarecidamente que lo copies y lo publiques en tu blog o que lo menciones en tu cuenta de Twitter o en Facebook usando el hashtag #redneutral. ¡Muchas gracias!

Estados de Venezuela en SELECT OPTION de HTML

| Posted in General |

2

Que fastidio enorme no tener a la mano la lista oficial de los 24 estados de Venezuela cuando se le necesita; en especial si se trata de un formulario HTML.

Así que acá lo tienen, por si acaso alguno de ustedes lo llega a necesitar también ;-)


<select name="estados">
  <option>Amazonas</option>
  <option>Anzoátegui</option>
  <option>Apure</option>
  <option>Aragua</option>
  <option>Barinas</option>
  <option>Bolivar</option>
  <option>Carabobo</option>
  <option>Cojedes</option>
  <option>Delta Amacuro</option>
  <option>Distrito Capital</option>
  <option>Falcón</option>
  <option>Guarico</option>
  <option>Lara</option>
  <option>Mérida</option>
  <option>Miranda</option>
  <option>Monagas</option>
  <option>Nueva Esparta</option>
  <option>Portuguesa</option>
  <option>Sucre</option>
  <option>Táchira</option>
  <option>Trujillo</option>
  <option>Yaracuy</option>
  <option>Zulia</option>
  <option>Vargas</option>
</select>

Ah y no se olviden de JQOMBO por si acaso lo quieren pero desde una base de datos y con todas las ciudades vinculadas vía AJAX.

Traducción al español de CodeIgniter 2.0

| Posted in General |

3

Me tomé la libertad de acomodar la traducción al español del CodeIgniter 1.7.2 para adaptarla al 2.0

Y he aquí: DESCARGAR

Espero les sea de utilidad.

Editado: El link de descarga ahora ya no está en mediafire, sino en el sitio oficial de codeigniter.

10 errores comunes cuando se trabaja con MySQL

| Posted in General |

3

Lo primero, decir que está es una traducción y adaptación libre del artículo cuyo autor es Craig Buckler. Aclarado ello, conozcamos los 10 errores más comunes que cometen muchos programadores PHP cuando trabajan con MySQL.

1. Usar MyISAM en lugar de InnoDB.
MySQL tiene un considerable número de motores de almacenamiento, entre los cuales lo más destacados con MyISAM e InnoDB.

Pero MyISAM es quien viene por defecto en toda instalación MySQL. Y muchos ignoramos esto y sencillamente lo dejamos así, pero MyISAM no soporta foreign key ni transacciones. Además, la tabla completa es bloqueada cada vez que insertamos o actualizamos un registro causando problemas de rendimiento.

La solución es simple: Usar InnoDB

2. Usar las funciones mysql de PHP.
PHP provee un amplio set de funciones para trabajar con MySQL, y eso ha sido así desde el principio (muchos años). Funciones tales como mysql_connect, mysql_query, mysql_fetch_assoc, etc. pero ignoramos una importante mejora implementada desde PHP 5: la librería mysqli.

Y tal como cita el manual oficial de PHP:

Si se utiliza una versión de MySQL 4.1.3 o posterior, se recomienda encarecidamente utilizar la extensión mysqli en su lugar.

mysqli tiene notables ventajas:

  • Una interfaz opcional orientada a objetos
  • Prepared Statements (sentencias preparadas) que ayudan a prevenir los ataques de inyección SQL e incrementa el performance.
  • Soporta la ejecución de múltiples sentencias y transacciones

Además, usted podría considerar usar PDO si planea dar soporte a distintos tipos de bases de datos.

3. No filtrar las entradas del usuario
Este es quizá el peor de todos los errores. NUNCA CONFÍE EN LO QUE LOS USUARIOS ENVÍEN. Validar todo desde el lado del servidor es algo obligatorio, no confíe en las validaciones JavaSript. Atacar un sitio por inyección SQL es tan simple como:


$username = $_POST["name"];
$password = $_POST["password"];
$sql = "SELECT userid FROM usertable WHERE username='$username' AND password='$password';";
// run query...

Esto puede ser crackeado con tan sólo ingresar “admin’; –” en el campo de username. La cadena SQL quedaría así:


SELECT userid FROM usertable WHERE username='admin';  

El atacante ha logrado ingresar al sistema como ‘admin’ sin siquiera necesitar el password, porque fue comentado dentro del SQL.

4. No usar UTF-8
Un gran problema respecto al manejo de los caracteres y la internacionalización (otros idiomas) es el mal uso del charset. Sin importar si lo que desarrollamos sea en inglés o español (o cualquier otro) usar UTF-8 es una gran solución. Aunque PHP no ofrezca del todo un soporte a UTF-8 (al menos hasta la versión PHP 6) MySQL si posee dicho soporte, MySQL character sets

5. Favorecer a PHP por sobre MySQL
MySQL posee un amplio set de funciones que puede correr como parte de la sentencia QUERY, pero muchos lo ignoramos.

Por ejemplo, para obtener un valor promedio de los salarios en una tabla, un programador realizaría una consulta a MySQL y traería hasta PHP todos los registros a calcular; y posteriormente realizaría el cálculo del promedio con la aritmética de PHP (y que es el lenguaje que conoce); pero la mejor opción hubiese sido aprovechar la función AVG() que trae MySQL y nos ahorramos procesos innecesarios.

La regla general es usar en la mayor medida posible las funciones pre-construidas en la base de datos, ahorrando procesos a PHP.

6. No optimizar las consultas
El 99% de los problemas de performance en PHP se deben a sentencias y consultas SQL mal hechas. MySQL cuenta con herramientas que nos permiten medir y probar nuestras consultas a fin de buscar mejores opciones. Sentencia EXPLAIN, Query Profiler y algunas otras herramientas que le ayudaran a robustecer sus SELECT.

7. Usar tipos de campo inadecuados
MySQL ofrece un amplio rango de tipos numéricos, cadenas y de fechas. Si usted va a almacenar una fecha, use el campo indicado para ello DATE o DATETIME. Usar enteros o cadenas para ello, sólo le traerá problemas.

Es importante determinar cual es el tipo de campo ideal para cada dato que vaya a almacenar. Piénselo bien, MySQL ofrece bastante de donde escoger.

8. Usar * en las consultas SELECT
Es un error terriblemente común. No use * para retornar todas las columnas de una tabla. No sea flojo ! Sea específico en definir cuales campos desea consultar, incluso si los llega a necesitar todos.

9. No indexar o indexar más de lo necesario
Como regla de oro, indexe sólo donde una columna sea solicitada en una sentencia WHERE de una consulta SELECT. Saber hacerlo mejorará el performance de su base de datos y en consecuencia incrementará la velocidad de todo su sistema.

10. Olvidar respaldar !
Aunque no lo crea, las cosas no siempre funcionan como esperamos. Las bases de datos se pueden corromper, el disco duro estropearse, un incendio puede consumir su datacenter e incluso su proveedor puede irse a banca rota !

Perder datos es algo catastrófico e imperdonable, tome todas las medidas necesarias para tener siempre a mano respaldos de sus datos, de forma automatizada y remota.

11 La ñapa: no considerar otras bases de datos.
MySQL es sin duda uno de los más famosos y extendidos entre los programadores PHP, pero no es la única opción. Existen muchas alternativas como PostgreSQL y Firebird quienes son además Software Libre y no controlados por una corporación como sí lo es MySQL. Incluso SQLite puede resultar en una interesante alternativa para aplicaciones pequeñas y embebidas.