Cómo crear un servicio personalizado para consumir APIs externas en Laravel

Inicio   /   Cómo crear un servicio personalizado para consumir APIs externas en Laravel

Blog Cómo crear un servicio personalizado para consumir APIs externas en Laravel


Cómo crear un servicio personalizado para consumir APIs externas en Laravel


En muchas aplicaciones web, especialmente en Laravel, es común que necesitemos conectarnos a servicios de terceros, como pasarelas de pago, plataformas de mensajería o servicios de envío. Para mantener nuestro código limpio y escalable, lo mejor es encapsular esa lógica en servicios personalizados.


1. ¿Por qué usar servicios en Laravel?

  • Separas la lógica externa del resto de tu app
  • Facilita pruebas y mantenimiento
  • Evitas duplicar código en controladores


2. Ejemplo práctico: consumir una API externa

Supongamos que queremos conectarnos a una API externa para obtener información de productos. Usaremos el cliente HTTP de Laravel (Http::), que está basado en Guzzle.


🛠 Paso 1: Crear el servicio

Usa Artisan para crearlo:

php artisan make:service ProductApiService

Luego edita el archivo generado (si no existe, créalo en app/Services):

// app/Services/ProductApiService.php
namespace App\Services;

use Illuminate\Support\Facades\Http;

class ProductApiService
{
    protected $baseUrl;

    public function __construct()
    {
        $this->baseUrl = config('services.product_api.url');
    }

    public function getAllProducts()
    {
        $response = Http::get($this->baseUrl . '/products');
        return $response->json();
    }

    public function getProductById($id)
    {
        $response = Http::get($this->baseUrl . "/products/{$id}");
        return $response->json();
    }
}

🔐 Paso 2: Configurar el archivo .env

# .env
PRODUCT_API_URL=https://fakestoreapi.com

⚙ Paso 3: Agregar a config/services.php

'product_api' => [
    'url' => env('PRODUCT_API_URL'),
],

🚀 Paso 4: Usarlo en un controlador

// app/Http/Controllers/ProductController.php
use App\Services\ProductApiService;

class ProductController extends Controller
{
    public function index(ProductApiService $service)
    {
        $products = $service->getAllProducts();
        return view('products.index', compact('products'));
    }
}

3. Bonus: manejo de errores


Para evitar fallos inesperados, maneja excepciones y errores:

public function getAllProducts()
{
    try {
        $response = Http::timeout(5)->get($this->baseUrl . '/products');
        return $response->successful() ? $response->json() : [];
    } catch (\Exception $e) {
        \Log::error('API Error: ' . $e->getMessage());
        return [];
    }
}

4. Conclusión


Centralizar la lógica de integración en servicios es una de las mejores prácticas en Laravel. Te permite mantener el código organizado, testeable y flexible para futuros cambios o mejoras.


¿Ya usas servicios en tu aplicación? ¡Déjame saber en los comentarios cómo lo implementaste!

Tags: Laravel, api, services, rest,

Ultimas Noticias


¿Qué es el diseño de interfaz de usuario (UI)?

Cada dispositivo centrado en el ser huma


Una guía detallada para construir una startup de SaaS en 2022

El software como servicio (SAAS) es un m


Aprende php parte 1

¿Qué es PHP?PHP o preprocesador de hip


Que necesitas para ser desarrollador backend

Cuando usas una aplicación móvil o web


📝 Cómo Crear un Blog Optimizado para SEO con Laravel

Laravel permite construir un blo


¿Cómo los servicios de redes sociales son beneficiosos para su negocio?

Cuando se trata de generar rentabilidad,