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:
Common Object Request Broker Architecture (CORBA) es un estándar que permite que diversos componentes de software escrit[...]
Es recomendable tener actualizado la Maquina Virtual Java de nuestro equipo para poder disfrutar de las mejoras que trae[...]
Código Único de Factura para el Nuevo Sistema de Facturación Electrónica en Bolivia desarrollado en el lenguaje PHP 7 (H[...]
En post anteriores se vio algunos conceptos y ejemplos de lo que es el patrón MVC, dando un paso más adelante ahora con[...]
Hasta este momento utilizamos un solo Activity para desarrollar nuestras aplicaciones, sin embargo es común que las apli[...]
En este segundo post sobre Android y SQLite, veremos el uso de los métodos de gestión de base de datos más utilizados, e[...]