El manejo correcto de excepciones permite que nuestras aplicaciones sean robustas, tolerante a fallos y amigable con el usuario final, de ahí la gran importancia en un correcto manejo de excepciones. Al trabajar con laravel, este framework nos brinda dos maneras de lidiar con estos contratiempos, una de ellas es el uso de la sentencia «THROW», la sentencia throw es un mecanismo de propósito general para generar excepciones en PHP. su propósito principal es señalar condiciones excepcionales dentro de la lógica de la aplicación.
A continuación implementemos la sentencia throw en un caso practico bajo un proyecto Laravel 11
Paso 1. UserService
Implementamos una clase Service donde se declara el metodo «findUserById» , el mismo realiza la busqueda de un usuario dado su ID, si no lo encuentra, retornara una excepción con el mensaje «Usuario no existe!», caso contrario, retorna al usuario encontrado.
<?php namespace App\Services; use Exception; use App\Models\User; class UserService { public function findUserById( $id ){ $user = User::find( $id ); if (!$user) { throw new Exception("Usuario no existe!"); } return $user; } }
Paso 2. FooController
En nuestra clase FooController, se inyecta el servicio UserService desde el constructor. Luego cuando se llama al método show(), se utiliza el método findUserById() del UserService. Si el usuario no existe, se captura la excepción y se responde con una pagina de error 404. Claro que si nuestra aplicación fuera un API, se responderia con un JSON, esto demuestra como capturamos la excepción, la personalizamos y actuamos segun lo que se requiera.
<?php namespace App\Http\Controllers; use Illuminate\Http\Request; use App\Services\UserService; class FooController extends Controller { protected $userService; public function __construct(UserService $userService) { $this->userService = $userService; } public function show( $id ){ try { $user = $this->userService->findUserById($id); return view('user.profile', ['user' => $user]); } catch (\Exception $e) { return response()->view('errors.user-not-found', ['message' => $e->getMessage()], 404); } } }
Paso 3. View
Tanto si encontramos usuario como si no, se implementa dos vistas.
view/user/profile.blade.php
{{ $user }}
view/errors/user-not-found.blade.php
{{ $message }}
Paso 4. Route
Route::get('/users/{id}', [FooController::class, 'show']);
Y probando tenemos:
Pero si tenemos una excepción obtenemos:
🙂 Una de las preguntas más buscadas por programadores java es la de crear componentes swing en tiempo de ejecución, eso[...]
En este post realizaremos un pequeño ejemplo de validación de archivos XML utilizando el esquema XSD y el lenguaje PHP ([...]
Cuando desarrollamos aplicaciones para android como programadores nos interesa la velocidad al tiempo de depurar el códi[...]
Un BLOB en SQL es un tipo incorporado que almacena un Objeto Binario Grande como un valor de columna en una fila de una[...]
Continuando con estos post de Cliente/Servidor, en esta oportunidad realizaremos un ejemplo usando un dispositivo móvil[...]
¿Que son los archivos JNLP? Java Network Launching Protocol (JNLP) es una especificación usada por Java Web Start. Esta[...]