¿ Es necesario un framework ? Simplificando el desarrollo de software

Esta es una discusión que he tenido en bastantes ocasiones con pares y alumnos. La idea de este post es explicar un poco lo que se ha logrado con todas estas discusiones.

En muchos de los casos durante la universidad no hemos tenido la necesidad de desarrollar un software complejo, un software el cual deba de adaptarse a las necesidades del entorno, las modificaciones de ciertas librerías o simplemente al tiempo. La semana pasada le di el ejemplo a un alumno sobre codeignigter, en mi caso fue el primer framework que utilicé para desarrollo web utilizando php y actualmente ( no se si vaya a cambiar pronto) ya no es compatible con las nuevas versiones de php. Esto le puede pasar a cualquier desarrolo, la cantidad de actualizaciones, parches y modificaciones que salen anualmente son muchas más de las que podemos contar. Si esto le pasa a una aplicación que es mantenida por cientos de personas en la comunidad .. ¿Que nos espera a una aplicación desarrollada por nosotros ?

Ojo, esto no es para asustar a nadie, es simplemente para generar conciencia de lo que podría a pasar si no prevenimos.

Es solo cosa de mirar algunas de las aplicaciones más usadas del momento, como lo es Flickr y Facebook, ambas son en base a php y la verdad no creo que vayan a dejar de ser compatibles con sus nuevas versiones o no estén preparados para situaciones como esa. Deben de tener docenas si no cientos de desarrolladores con acceso al código que ocupan y tienen que además tener un estándar que seguir para publicar su código o simplemente para entender el que ya está escrito.

Lo bueno es que ya muchos desarrolladores han lidiado con los mismos problemas a los cuales podríamos enfrentarnos y han desarrollado frameworks en los cuales se han recopilado los conocimientos de muchos desarrolladores para hacer nuestras aplicaciones aún más fácil de realizar.

Ok, podemos decir que los frameworks están para hacer que un desarrollo complejo se convierta en un desarrollo simple. Es posible que para aplicaciones sencillas si agreguemos una complejidad innecesaria al implementar un framework, pero este post se basa en aplicaciones un poco más complejas, esas en las que se requiere ya de un equipo, en las que usaremos manejo de versiones, en las que dividiremos el código en hitos y cada uno de ellos se convertirá en un entregable de un proyecto.

Ok, ¿ pero que es un framework ?

Wikipedia : «A software framework is a universal, reusable software environment that provides particular functionality as part of a larger software platform to facilitate development of software applications, products and solutions. «

Personalmente me gusta el término de «un esqueleto que incluye lo básico para generar una aplicación compleja sin la complejidad requerida para realizarla«.

Si partimos de lo básico, un framework separa la lógica de las vistas, ordenando la forma en que desarrollaremos. De ahora en adelante hablaré un poco del Modelo Vista Controlador ( MVC ). En este modelo el framework provee una clara separación en 3 capas, y la posibilidad de interactuar entre ellas. Teniendo estas separaciones será muy difícil para nosotros desarrollar de manera inadecuada, aunque he visto casos que al no entender el concepto igual logran hacerlo pero se dan cuenta rápidamente que hay algo mal.

En general los frameworks se encargarán de conectar a la Base de datos por nosotros,  se encargan que los datos sean accesibles por las vistas y algunos incluso nos facilitan la generación de código CRUD ( Create Read Update Delete ) para poner nuestra aplicación en marcha lo antes posible. Si tuvieramos que implementar esto por nuestra cuenta ( créanme tuve que hacerlo hace años atrás ) nos demoraríamos mucho tiempo y agregaríamos esa complejidad al desarrollo que tanto tratamos de ignorar. Teniendo esto en cuenta nosotros o nuestro equipo de puede enfocar simplemente en el desarrollo y éxito de la aplicación olvidándonos de desarrollo que cientos de personas ya han hecho por nosotros.

Hay dos frases que me gusta recalcar cuando hablamos de un framework :

  1. No reinventar la rueda
  2. Enanos parados sobre los hombros de gigantes. ( nanos gigantum humeris insidentes )

Ambas se refieren a lo lejos que podemos llegar basándonos en conocimiento ya escrito. ¡ Imagínense que sería de la física si tuviéramos que descubrir la ley de gravedad por cada científico que quisiera explicar por que una manzana se cae al piso ! Ahora piensa nuevamente por que quieres desarrollar algo que ya cientos de personas lo han hecho antes que tu, ¿ ahora suena más ridículo no ?

¿ Como elegir un framework ?

Les recomiendo que cumpla la mayoría de los puntos a continuación.

  • Que sea sencillo de utilizar. La idea es simplificar, no hacer más complejo el desarrollo.
  • Mejore el rendimiento de la aplicación. Muchos framework por ejemplo usan caché para mejor rendimiento.
  • Asegure seguridad. Esto es muy importante y es una de las mejores razones de usar el framework.
  • Separe el lenguaje de las vistas.
  • Ojalá sea Orientada a Objetos !
  • Habilidad de poder configurar
  • Que tenga buena documentación.
  • Que tenga una buena comunidad. La comunidad es la que te ayudará cuando tengas problemas.

 

Ok, espero que con todo lo anterior ya puedas decir que un framework si es necesario no importando el lenguaje que utilizarás. Yo hace un tiempo que uso Yii y me he estado portando a Yii2, cumple con todas las características que dije anteriormente y al parecer se ajusta muy bien a mi mindset, ahora la pregunta es ¿ cual framework usarás tu ?.

 

 

¡Mantengamos el contacto!

Me encantaría que te mantuvieras al día con el contenido que estoy generando. Recuerda que no es solo el blog, son las redes sociales, libros, y distintos pódcast 😎.

Hago todo lo posible para no hacer Spam,

¡MANTENGÁMONOS EN CONTACTO!

Me encantaría que te mantuvieras al día con el contenido que estoy generando. Recuerda que no es solo el blog, son las redes sociales, libros, y distintos pódcast 😎.

Hago todo lo posible para no hacer Spam,

[ CODEIGNITER ] Dynamic base_url – base_url dinámica

En muchos casos, si estas desarrollando de manera colaborativa, usas cvs, svn, etc, es posible que un mismo proyecto lo pruebes en maquinas o servidores distintos. Uno de los problemas con los que me topé, fue el hecho de teenr que cambiar el » $config[‘base_url’] » , cada vez que ocupaba un computador distinto. 

Si bien, este no es un problema «TERRIBLE» se vuelve tedioso al momento de desarrollar de manera colaborativa, en este caso con codeigniter. Para solucionarlo, simplemente, haremos que el config..php (application/config/config.php) establezca nuestro base_url dependiendo de donde nos encontremos.

 

Sustituiremos

$config['base_url']    = "http://localhost/Proyectos/

Con un simple switch, que además depende del nombre del servidor donde nos encontremos. 

<?php

define('SERVER_NAME_DEV', 'localhost');
define('SERVER_NAME_EMPRESA', 'www.PAGINA_UNO.cl');
define('SERVER_NAME_FINAL', 'www.PAGINA_DOS.cl');

//Obtenemos el nombre actual para el servidor donde nos encontramos
$nombreServerActual = $_SERVER['SERVER_NAME'];
switch($nombreServerActual)
{
    case SERVER_NAME_DEV:
            $config['base_url'] = "http://localhost/Proyectos/";
            break;
    case SERVER_NAME_EMPRESA:
            $config['base_url'] = "http://www.PAGINA_UNO.cl";
            break;
    case SERVER_NAME_FINAL:
            $config['base_url'] = "http://www.PAGINA_DOS.cl";
            break;
    default:
            $config['base_url'] = "http://localhost/Proyectos/";
            break;
}
?>

Con este pequeño truco, no importa en cual server estemos desarrollando con CodeIgniter. El resultado siemrpe será el mismo, nuestra página sin tener que cambiar el base_url.

Con este sistema, no importa la CANTIDAD de servidores de desarrollo, o incluso los distintos nombres que pueda tener tu página.

 

 

[CODEIGNITER] [CALLBACKs] Como generar nuestros callbacks con parámetros

Cuando generamos los callbacks, nos vemos en la necesidad de usar parámetros por lo general. De la misma forma que el «matches» de codeigniter compara dos campos proporcionados por nosotros, en general nos gustaría por ejemplo comparar un usuario y un password , por ejemplo, para hacer un pequeño sistema de autentificación.

 Simplemente creamos el callback, y además de recibir el parámetro primero, el cual es el field que nosotros poseemos, recibiremos a continuación todos los parámetros que necesitemos (El truco esta en la llamada).

 

Si quiero crear un callback para revisar si una clave corresponde a un usuario en particular , debería crear un callback que lo revisara al momento de validar el formulario.

<?php
function check_usuario_clave($usuario,$clave)
{


}
?>

 Al momento de llamar al calback es cuando debemos hacer la diferencia. En este caso en vez de llamar a callback_check_usuario_clave , llamaremos a callback_check_usuario_clave[clave] .

Hasta ahora, nuestro parámetro clave tendrá simplemente el valor de «clave», por lo tanto debemos obtener el contenido original.

<?php
function check_usuario_clave($usuario,$clave)
{
$clave = $_POST[$clave];

}
?>

De esta manera podemos trabajar con ambas variables, sin necesidad de ejecutar funciones aparte de los callback. En este caso la variable $clave es redefinida para contener el valor que nos interesa. Espero que les sirva y éxito ! ! 

 

 

 

 

Share to...