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:
El siguiente código te permite abrir enlaces web desde un JLabel, ademas aprovechando el soporte a etiquetas HTML del co[...]
JSON es un formato de texto ligero para el intercambio de datos ampliamente usado en los Servicios Web. En este post uti[...]
En este tutorial «Android Bolivia» construiremos nuestra propia aplicación para molestar a los amigos con sonidos divert[...]
Java 8 trae consigo una nueva versión del motor de JavaScript llamada Nashorn, este motor introduce mejoras de rendimien[...]
Dando respuesta a una interrogante sobre el como crear objetos en tiempo de ejecución y como manipular estos, desarrolle[...]
En este post dejo una forma de como utilizar imágenes en un JTable ademas de implementar MouseListener para realizar dif[...]