Aprende Java Aprende Php Aprende C++ Aprende HTML 5 Aprende JavaScript Aprende JSON Aprende MySQL Aprende SQLServer Aprende Visual Basic 6 Aprende PostgreSQL Aprende SQLite Aprende Redis Aprende Kotlin Aprende XML Aprende Linux VSC Aprende Wordpress Aprende Laravel Aprende VueJS Aprende JQuery Aprende Bootstrap Aprende Netbeans Aprende Android
Sigueme en Facebook Sigueme en Twitter Sigueme en Instagram Sigueme en Youtube Sigueme en TikTok Sigueme en Whatsapp
Home / Laravel / Manejo de excepciones: Uso de Throw Exception en Laravel 11

Manejo de excepciones: Uso de Throw Exception en Laravel 11

Por jc mouse jueves, agosto 8, 2024

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:

Tags

Artículos similares

Ejemplo completo de CORBA en Java

Common Object Request Broker Architecture (CORBA) es un estándar que permite que diversos componentes de software escrit[...]

Cambiar plataforma JDK en Netbeans

Es recomendable tener actualizado la Maquina Virtual Java de nuestro equipo para poder disfrutar de las mejoras que trae[...]

Código Único de Factura en PHP

Código Único de Factura para el Nuevo Sistema de Facturación Electrónica en Bolivia desarrollado en el lenguaje PHP 7 (H[...]

Crea tu blog con el patrón MVC y php

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[...]

Trabajando con varios Activitys

Hasta este momento utilizamos un solo Activity para desarrollar nuestras aplicaciones, sin embargo es común que las apli[...]

SQLite INSERT, UPDATE, DELETE, QUERY

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[...]