Php + XDebug + Laragon + Visual Studio Code!
Como programador una de las opciones que menos me gusta pero que realmente es necesario es el debug, mas en los casos cuando el desarrollo falla y no tienes ni la mínima idea de como resolverlo.
Recién estoy llevando los cursos de la Especialidad de EDteam sobre Php con la profesora Yesi Days, por lo cual en este artículo no pretendo enseñarte cuales son los fundamentos de la depuración en Php, más bien como preparar el entorno para poder realizar la depuraciones de nuestro código por que realmente puede hacernos la vida más fácil.
Xdebug
Xdebug es una extensión de PHP que apunta a ayudar en el proceso de depuración de sus aplicaciones.
Xdebug ofrece características como:
- Seguimiento automático de la pila en caso de error
- Función de registro de llamadas
- Mostrar características como la salida var_dump () mejorada y la información de cobertura de código.
Xdebug es altamente configurable y adaptable a una variedad de situaciones. Por ejemplo, los seguimientos de la pila (que son extremadamente útiles para monitorear qué está haciendo su aplicación y cuándo) se pueden configurar a cuatro niveles de detalle diferentes. Esto significa que puede ajustar la sensibilidad de la salida de Xdebug ayudándole a obtener información granular sobre la actividad de su aplicación.
Los seguimientos de pila le muestran dónde ocurren los errores, le permiten rastrear llamadas a funciones y detallar los números de línea de origen de estos eventos. Todo lo cual es información fantástica para depurar su código.
Puedes echar un vistazo link a la guía de instalación de Xdebug que se ofrece en la página oficial.
Instalación Xdebug
Para ello, necesitaremos descargar la versión de Xdebug, adecuada a nuestra versión de PHP. Hay que tener en cuenta que necesitaremos tener PHP 7.0 o superior.
Empezaremos averiguando que versión de Xdebug nos corresponde para la instalación de PHP de nuestra máquina. En este post utilizaremos Laragon pero funciona igual si tienes instalado XAMPP el proceso es muy sencillo, tan solo tenemos que abrir el navegador y escribiremos en la barra de direcciones localhost, y en el menú de la página que aparecerá pulsaremos la opción de PHPInfo.
Cómo agregar Xdebug a Laragon
Si tienes problemas en cargar esta pantalla puedes realizar los siguientes pasos:
- En la barra de tareas de windows dale click al icono de Laragon.
- Selecciona PHP
- En el menú desplegable selecciona Quick Setting.
- Selecciona xdebug.
Aparecerá una advertencia indicando si necesitamos ayuda para agregar Xdebug a Laragon.
Nota: al aceptar la advertencia nos redireccionará al siguiente
Link, en el cual nos muestra el método para agregar Xdebug a Laragon usando phpinfo() y asistente de Xdebug.
Usando de phpinfo () y asistente de Xdebug
-
Copie todo el contenido de phpinfo(): http://localhost/?Q=info
Tips: Puedes Seleccionar toda la información con solo presionar Ctrl + A.
-
Pegue los datos copiados al formulario en la página del asistente de Xdebug: http://xdebug.org/wizard
Tips: Asegúrese de que al momento de pegar la información de phpInfo() en el formulario de Xdebug borrar los espacios al inicio y final.
Una vez concluido estos pasos se nos muestra las instrucciones que necesitaremos para usar la extensión Xdebug.
Tal y como nos sugiere debemos descargar la extensión de Xdebug (en mi caso seria la php_xdebug-2.6.1-7.2-vc15-x86_64.dll)
-
Mover o copiar la extensión descargada a la ruta que nos indica Extensions directory (en mi caso seria C:\laragon\bin\php\php-7.2.11-Win32-VC15-x64\ext)
Tips: Esta dirección puede variar según donde tengas instalado Laragon.
-
Ahora editaremos el fichero C:\laragon\bin\php\php-7.2.11-Win32-VC15-x64\php.ini, y añadiremos al final las siguientes líneas.
Puedes copiar y pegar para que no tengas problemas.
[XDebug] xdebug.remote_enable = 1 xdebug.remote_autostart = 1 zend_extension=xdebug-2.6.1-7.2-vc15-x86_64
Tips: el valor de zend_extension debe de ser el que nos indica la página de Xdebug en sus instrucciones.
Si tienes miedo de trastear el archivo de configuración de php.ini puedes realizar los siguientes pasos explicados anterior mente el cual solo agregara la siguiente linea zend_extension=xdebug-2.6.1-7.2-vc15-x86_64 al archivo php.ini:
1) En la barra de tareas de windows dale click al icono de Laragon.
2) Selecciona PHP
3) En el menú desplegable selecciona Quick Setting.
4) Selecciona Xdebug.
Para verificar que todo el proceso anterior ha tenido éxito, consultaremos otra vez la opción de PHPInfo, y comprobaremos que en el texto que sale al lado de la imagen de zendengine, aparece “with Xdebug” tal y como se muestra en la siguiente imagen (otra forma de comprobarlo es buscar el texto xdebug en esta página).
Configurando Visual Studio Code para depurar código PHP
Una vez que hemos realizado la instalación de Xdebug ya podemos comenzar a depurar nuestros código php con Visual Studio Code. Para ello debemos asegurarnos de tener instalado en este editor la extensión de “PHP Debug”.
Instalación de PhpDebug
Las extensiones las buscaremos usando el icono de Extensiones del menú de la izquierda con forma cuadrada pulsando en la caja de texto Php Debug y la instalaremos.
Tips: Una vez instalado, para asegurarnos de que funciona, pulsaremos el botón azul Recargar. Y si nos aparece, también pulsaremos el botón con el mensaje “Volver a cargar Window”.
Configuración de PhpDebug en Visual Studio Code
- En este momento, es cuando abriremos nuestro proyecto (Archivo -> Abrir Carpeta).
-
Después, accederemos a la Vista de depuración:
Tips: Para abrir la vista de depuración, haga clic en el ícono de depuración en la barra de actividad en el lado de Código VS. También puede utilizar la combinación de teclas Ctrl + Shift + D.
-
Luego agregaremos una configuración para depurar PHP con Xdebug.
Tips: En la parte superior hay un selector (2), y a su lado, un engranaje.
Al pulsar en el selector nos pedirá que indiquemos el lenguaje a depurar. Se abrirá el archivo launch.json y mostrara unas líneas de código por defecto, que dejaremos tal cual
-
En nuestro código PHP, agregaremos puntos de interrupción haciendo click a la izquierda del número de línea. Veremos cómo aparecen puntitos rojos en cada línea esto son puntos de interrupción.
-
En el archivo setting.json agrega el siguiente código.
Puedes copiar y pegar en tu archivo setting.json para que no tengas problemas.
// CONFIGURACIÓN PARA PHP // // PHP // Señala al ejecutable PHP. "php.validate.executablePath": "C:\\laragon\\bin\\php\\php-7.2.11-Win32-VC15-x64\\php.exe", // // Indica si linter se ejecuta al guardar o al escribir. "php.validate.run": "onType", // // PHP Intellisense // The path to a PHP 7+ executable. "php.executablePath": "C:\\laragon\\bin\\php\\php-7.2.11-Win32-VC15-x64\\php.exe"
Pulsamos el botón de Iniciar depuración, y después abrimos el navegador con la dirección de nuestra página a depurar.
Cuando el navegador empiece a cargar la página, Visual Studio Code tomará el control y nos permitirá ir depurando paso a paso usando las típicas herramientas de depuración.
Al añadir la configuración para la depuración, Visual Studio Code habrá creado una carpeta .vscode dentro de la carpeta de nuestro proyecto con la configuración de para la depuración. A partir de entonces, cada vez que abramos nuestro proyecto, tan solo tendremos que ir a la opción de depuración, poner algún punto de interrupción y darle a la flecha verde. Si por error borramos esa carpeta, tendremos que volver a repetir los pasos para volver a añadir la configuración.
Navegando en la web me encontré esta imagen donde se muestra mas detallada la características de depuración de Visual Studio Code, te dejo el link por si quieres seguir profundizando en el tema de Debug con Visual Studio Code.
Conclusión
Hemos llegado al final de este post, un poco extenso pero espero te ayude mucho.
¡Listos para depurar código PHP, sin miedo al éxito!
Top comments (1)
If you are a macOS user, ServBay.dev is worth to try. You don't need to spend some time or couple of days to setup anything. Just download it and you can use it immediately. You can run multiple PHP versions simultaneously and switch between them effortlessly.
Honestly, this tool has greatly simplified my PHP development and is definitely worth trying!