CursosEmpresasBlogLiveConfPrecios

Agregando Logging a API

Clase 14 de 22 • Curso de APIs con .NET

Clase anteriorSiguiente clase

Contenido del curso

Introducción a API en .NET

  • 1
    Domina las API con .NET

    Domina las API con .NET

    02:50 min
  • 2
    Prerrequisitos

    Prerrequisitos

    02:36 min
  • 3
    ¿Qué es una API?

    ¿Qué es una API?

    04:22 min
  • 4
    ¿Qué es REST?

    ¿Qué es REST?

    08:18 min
  • 5
    Creando tu primera API con .NET

    Creando tu primera API con .NET

    04:04 min

Funcionamiento de una API en .NET

  • 6
    Consumiendo API desde Postman

    Consumiendo API desde Postman

    05:33 min
  • 7
    Análisis del template para APIs de .NET

    Análisis del template para APIs de .NET

    10:51 min
  • 8
    Atributos para verbos HTTP

    Atributos para verbos HTTP

    14:56 min
  • 9
    Manejo de rutas

    Manejo de rutas

    09:51 min
  • 10
    Minimal API vs. Web API

    Minimal API vs. Web API

    08:36 min

Arquitectura y configuración

  • 11
    ¿Qué son los middlewares?

    ¿Qué son los middlewares?

    08:54 min
  • 12
    Creando un nuevo middleware

    Creando un nuevo middleware

    14:46 min
  • 13
    Inyección de dependencias

    Inyección de dependencias

    16:43 min
  • 14
    Agregando Logging a API

    Agregando Logging a API

    Viendo ahora
  • 15
    Documentando API con Swagger

    Documentando API con Swagger

    08:03 min

Manipulación de datos con Entity Framework

  • 16
    Agregando librerías para Entity Framework

    Agregando librerías para Entity Framework

    04:38 min
  • 17
    Configuración de Entity framework y clases base

    Configuración de Entity framework y clases base

    08:31 min
  • 18
    Creación de servicios

    Creación de servicios

    12:24 min
  • 19
    Inyectando servicios como dependencia

    Inyectando servicios como dependencia

    04:43 min
  • 20
    Creando controladores

    Creando controladores

    11:32 min
  • 21
    Probando API con una base de datos SQL server

    Probando API con una base de datos SQL server

    14:03 min

Outro

  • 22
    Retrospectiva: APIs con .NET

    Retrospectiva: APIs con .NET

    03:05 min
  • Tomar el examen del curso
    • Emerson Cedeño

      Emerson Cedeño

      student•
      hace 4 años

      luego de haber hecho el cambio a "Debug" en el appsettings y no ver los correspondientes logs en la consola, me di cuenta que los cambios no los había hecho en el appsettings.Development.json, pilas con en dónde hacen los ajustes trabajando con estos archivos de configuración por entorno

        Emanuel Alejandro López

        Emanuel Alejandro López

        student•
        hace 4 años

        GAAAAAAA

        Juan David Balanta Rentería

        Juan David Balanta Rentería

        student•
        hace 3 años

        Excelente.

      Erick Edgardo Marroquin Escobar

      Erick Edgardo Marroquin Escobar

      student•
      hace 3 años

      .Net es simplemente asombroso.

      NELSON FERNANDO PINZON ARANZAZU

      NELSON FERNANDO PINZON ARANZAZU

      student•
      hace 3 años

      Asi implemente logger en la clase HelloWorldController

      using Microsoft.AspNetCore.Mvc; namespace mywebapi.Controllers; [ApiController] [Route("api/v1/[controller]")] public class HelloWorldController : ControllerBase{ IHelloWorldService helloWorldService; private readonly ILogger<HelloWorldController> _logger; public HelloWorldController(ILogger<HelloWorldController> logger,IHelloWorldService helloworld) { _logger = logger; helloWorldService = helloworld; } public IActionResult Get() { _logger.LogInformation("Saludando el mundo"); return Ok(helloWorldService.GetHelloWorld()); } }
      Platzi Team

      Platzi Team

      student•
      hace 3 años

      Agregando Logging a API


      Agregar logging a una API es importante para tener una visibilidad completa sobre la actividad de la API y para poder solucionar problemas más eficientemente.

      private readonly ILogger<WeatherForecastController> _logger; public IActionResult Post([FromBody] WeatherForecast weatherForecast) { _logger.LogDebug("Log Al Insertar Data"); ListWeatherForecast.Add(weatherForecast); return Ok(); }

      Algunos de los niveles de registro comúnmente utilizados incluyen:

      • Trace: Información detallada y de diagnóstico que se utiliza principalmente durante la depuración y el desarrollo.
      • Debug: Información adicional que se utiliza durante la depuración y el desarrollo.
      • Information: Información general que puede ser útil para comprender lo que está sucediendo en la aplicación.
      • Warning: Información que indica que algo no está funcionando según lo previsto, pero que no impide el funcionamiento de la aplicación.
      • Error: Información que indica que un error ha ocurrido y que puede afectar el funcionamiento de la aplicación.
      • Critical: Información que indica un error grave que puede impedir el funcionamiento de la aplicación.

      Para configurar estos niveles de comunicacion, lo hacemos desde el archivo appsettings.json de la siguiente manera:

      "Logging": { "LogLevel": { "Default": "Debug | Information | Warning", "Microsoft.AspNetCore": "Warning" } },
      Emerson Cedeño

      Emerson Cedeño

      student•
      hace 4 años

      cómo el sistema sabe en qué entorno me encuentro, así como en otros stacks puede uno crear más de estos archivos de configuración por entorno (por ejemplo: appsettings.Staging.json), y de ser así, dónde y qué ajustes tendrían que hacerse para que el sistema sepa qué archivo leer?

        Xavier Medina Veintimilla

        Xavier Medina Veintimilla

        student•
        hace 4 años

        ¡Hola! :D

        ¿Cuál es el problema que tienes?, ¿en qué te puedo ayudar? Puedes adjuntar imágenes arrastrándolas a esta ventana de comentario.

        Nunca pares de aprender 💚

        Marcos Avila Rodriguez

        Marcos Avila Rodriguez

        student•
        hace 4 años

        Por las variables de entorno, en las propiedades de la solución (si mal no recuerdo) se encuentra esta variable, entonces, si deseas crear una configuración en particular, tendrías que partir de ahí.

      Marcos Lanuza

      Marcos Lanuza

      student•
      hace 3 años

      Comparto mi implementación de logging 😊

      using Microsoft.AspNetCore.Mvc; namespace APIProj.Controllers; [ApiController] [Route("api/[controller]")] public class HelloWorldController : ControllerBase { IHelloWorldService helloWorldService; private readonly ILogger<HelloWorldController> _logger; public HelloWorldController(IHelloWorldService hw, ILogger<HelloWorldController> logger) { _logger = logger; helloWorldService = hw; } public IActionResult Get() { _logger.LogDebug("Logging from Get(). Hi!"); return Ok(helloWorldService.GetHelloWorld()); } [Route("get/bye")] public IActionResult GetBye() { _logger.LogDebug("Saying goodbye @ GetBye()"); return Ok(helloWorldService.GetByeWorld()); } }

      Ojo que en la interfaz de IHelloWorldService agregué el método GetBye()

        Fernando Vergel

        Fernando Vergel

        student•
        hace 3 años

        Gracias, estaba frenado en un error de syntax y esto me ayudo!

      Juan Felipe Barahona Gonzalez

      Juan Felipe Barahona Gonzalez

      student•
      hace 2 años

      Quizás a alguien le sirva...

      En la clase anterior, dejé la inyección de dependencias de la manera genérica:

      builder.Services.AddScoped<IHelloWorldService, HelloWorldService>(); ```Y al intentar al agregar el logger al controlador de HolaMundo me tiraba error sobre que no estaba llamando al constructor como se debía cuando llamaba al endpoint de HolaMundo. La manera de solucionarlo que encontré consiste en usar la manera del factory lambda ```js builder.Services.AddScoped<IHelloWorldService>((_) => new HelloWorldService()); ```Así que si les falla, esta podría ser una de las razones. Saludos
        Alan Fernandez

        Alan Fernandez

        student•
        hace 2 años

        Genio, muchas gracias !

      Dario Sarmiento Rojas

      Dario Sarmiento Rojas

      student•
      hace 3 años

      Cual es la diferencia entre appsettings.Development.json y appsettings.json???

        Miguel Teheran

        Miguel Teheran

        teacher•
        hace 3 años

        El appsettings.json son las configuraciones generales el appsettings.Development.json sobreescribe esos datos y agrega mas para el ambiente de develop. La forma de especificar el ambiente en .NET es usando una variable de entorno https://learn.microsoft.com/en-us/aspnet/core/fundamentals/environments?view=aspnetcore-7.0

      Miguel Angel Reyes Moreno

      Miguel Angel Reyes Moreno

      student•
      hace 3 años

      Reto conseguido con HelloWorld:

      using Microsoft.AspNetCore.Mvc; namespace webapi.Controllers; [ApiController] [Route("api/[controller]")] public class HelloWorldController: ControllerBase { IHelloWorldService helloWorldService; private readonly ILogger<HelloWorldController> _logger; public HelloWorldController(IHelloWorldService helloWorld, ILogger<HelloWorldController> logger) { helloWorldService = helloWorld; _logger = logger; } [HttpGet] public IActionResult Get() { _logger.LogInformation("This is the log for hello world!"); return Ok(helloWorldService.GetHelloWorld()); } }
      David Dávila

      David Dávila

      student•
      hace 2 años

      Por que el atributo List<> del Controlador no es una clase que utiliza la inyección de dependencias tambien?

      Este concepto es nuevo para mi

        Bryan Alejandro Zelada Lemus

        Bryan Alejandro Zelada Lemus

        student•
        hace 3 meses

        List es un tipo de dato dentro del lenguaje de programación C#, y acepta dentro de los <> un tipo, para especificar valga la redundancia que tipo de datos son los elementos dentro de la lista.

        Ej. List<Product>

      Joan Alexander Valerio Rodríguez

      Joan Alexander Valerio Rodríguez

      student•
      hace 3 meses

      Implementación usando LogInformation() en GreetingsController :)

      Evelio Vega

      Evelio Vega

      student•
      hace 3 años

      una duda, mi app no levanta por el puerto https, durante todo el curso he tenido q usar http, q puedo hacer ?

        Miguel Teheran

        Miguel Teheran

        teacher•
        hace 3 años

        A varios les ha pasado que raro, puede revisar el tema de los certificados depronto no los tienes instalados: https://learn.microsoft.com/en-us/dotnet/core/tools/dotnet-dev-certs

      ROMMEL DUAREZ SAENZ

      ROMMEL DUAREZ SAENZ

      student•
      hace 2 años

      y cuando se cambiaría el appsettings.json.?

      Mauricio Daniel Campos

      Mauricio Daniel Campos

      student•
      hace 3 años

      buenas! consulta, estoy implementando el consumo de una API pero tengo inconveniente para usar el certificado en las peticiones Get y Post

        Miguel Teheran

        Miguel Teheran

        teacher•
        hace 3 años

        trata de instalar los certificados nuevamente

        https://learn.microsoft.com/en-us/dotnet/core/additional-tools/self-signed-certificates-guide

      Francisco Javier Saavedra Alcala

      Francisco Javier Saavedra Alcala

      student•
      hace un año

      Ví el titulo de la clase y me emocioné pensando que trataria de autenticación 😂 🤡

      Juan Diego Sánchez Rodríguez

      Juan Diego Sánchez Rodríguez

      student•
      hace un año

      Cuál es la diferencia entre usar logger y usar Console.Write ?

      Mathías Cabrera

      Mathías Cabrera

      student•
      hace 2 años

      Comparto mi Logging en el Controlador de HelloWorld

      public class HelloWorldController: ControllerBase { IHelloWorldService helloWorldService; public readonly ILogger<HelloWorldController> logger; public HelloWorldController(IHelloWorldService helloWorld, ILogger<HelloWorldController> logger2) { helloWorldService = helloWorld; logger = logger2; } public IActionResult Get() { logger.LogInformation("Retornando 'Hello World'."); return Ok(helloWorldService.GetHelloWorld()); } }
      Luis Antonio Preza Padilla

      Luis Antonio Preza Padilla

      student•
      hace 2 años

      Cual es la diferancia de usar el ILogger parametrizado en el controlador y usar ILoggeFactory?

      JUAN DAVID MARTINEZ GONZALEZ

      JUAN DAVID MARTINEZ GONZALEZ

      student•
      hace 3 años

      Aporte de Implementación loggin controller HolaMundo

      ![](

      api.png

      Santiago Montero

      Santiago Montero

      student•
      hace 3 años

      Asi implemente el Loggin en el HelloWorldController, ademas no olvidar si queremos cambiar el logging hacerlo en archivo development

      **public class HelloWorldController : ControllerBase { private readonly ILogger<HelloWorldController> _logger; IHelloWordService helloWordlService; public HelloWorldController(IHelloWordService helloWorld, ILogger<HelloWorldController> logger) { _logger = logger; helloWordlService = helloWorld; } public IActionResult Get() { _logger.LogDebug("Retorno del Request hello world"); return Ok(helloWordlService.GetHelloWorld()); } >

    Escuelas

    • Desarrollo Web
      • Fundamentos del Desarrollo Web Profesional
      • Diseño y Desarrollo Frontend
      • Desarrollo Frontend con JavaScript
      • Desarrollo Frontend con Vue.js
      • Desarrollo Frontend con Angular
      • Desarrollo Frontend con React.js
      • Desarrollo Backend con Node.js
      • Desarrollo Backend con Python
      • Desarrollo Backend con Java
      • Desarrollo Backend con PHP
      • Desarrollo Backend con Ruby
      • Bases de Datos para Web
      • Seguridad Web & API
      • Testing Automatizado y QA para Web
      • Arquitecturas Web Modernas y Escalabilidad
      • DevOps y Cloud para Desarrolladores Web
    • English Academy
      • Inglés Básico A1
      • Inglés Básico A2
      • Inglés Intermedio B1
      • Inglés Intermedio Alto B2
      • Inglés Avanzado C1
      • Inglés para Propósitos Específicos
      • Inglés de Negocios
    • Marketing Digital
      • Fundamentos de Marketing Digital
      • Marketing de Contenidos y Redacción Persuasiva
      • SEO y Posicionamiento Web
      • Social Media Marketing y Community Management
      • Publicidad Digital y Paid Media
      • Analítica Digital y Optimización (CRO)
      • Estrategia de Marketing y Growth
      • Marketing de Marca y Comunicación Estratégica
      • Marketing para E-commerce
      • Marketing B2B
      • Inteligencia Artificial Aplicada al Marketing
      • Automatización del Marketing
      • Marca Personal y Marketing Freelance
      • Ventas y Experiencia del Cliente
      • Creación de Contenido para Redes Sociales
    • Inteligencia Artificial y Data Science
      • Fundamentos de Data Science y AI
      • Análisis y Visualización de Datos
      • Machine Learning y Deep Learning
      • Data Engineer
      • Inteligencia Artificial para la Productividad
      • Desarrollo de Aplicaciones con IA
      • AI Software Engineer
    • Ciberseguridad
      • Fundamentos de Ciberseguridad
      • Hacking Ético y Pentesting (Red Team)
      • Análisis de Malware e Ingeniería Forense
      • Seguridad Defensiva y Cumplimiento (Blue Team)
      • Ciberseguridad Estratégica
    • Liderazgo y Habilidades Blandas
      • Fundamentos de Habilidades Profesionales
      • Liderazgo y Gestión de Equipos
      • Comunicación Avanzada y Oratoria
      • Negociación y Resolución de Conflictos
      • Inteligencia Emocional y Autogestión
      • Productividad y Herramientas Digitales
      • Gestión de Proyectos y Metodologías Ágiles
      • Desarrollo de Carrera y Marca Personal
      • Diversidad, Inclusión y Entorno Laboral Saludable
      • Filosofía y Estrategia para Líderes
    • Diseño de Producto y UX
      • Fundamentos de Diseño UX/UI
      • Investigación de Usuarios (UX Research)
      • Arquitectura de Información y Usabilidad
      • Diseño de Interfaces y Prototipado (UI Design)
      • Sistemas de Diseño y DesignOps
      • Redacción UX (UX Writing)
      • Creatividad e Innovación en Diseño
      • Diseño Accesible e Inclusivo
      • Diseño Asistido por Inteligencia Artificial
      • Gestión de Producto y Liderazgo en Diseño
      • Diseño de Interacciones Emergentes (VUI/VR)
      • Desarrollo Web para Diseñadores
      • Diseño y Prototipado No-Code
    • Contenido Audiovisual
      • Fundamentos de Producción Audiovisual
      • Producción de Video para Plataformas Digitales
      • Producción de Audio y Podcast
      • Fotografía y Diseño Gráfico para Contenido Digital
      • Motion Graphics y Animación
      • Contenido Interactivo y Realidad Aumentada
      • Estrategia, Marketing y Monetización de Contenidos
    • Desarrollo Móvil
      • Fundamentos de Desarrollo Móvil
      • Desarrollo Nativo Android con Kotlin
      • Desarrollo Nativo iOS con Swift
      • Desarrollo Multiplataforma con React Native
      • Desarrollo Multiplataforma con Flutter
      • Arquitectura y Patrones de Diseño Móvil
      • Integración de APIs y Persistencia Móvil
      • Testing y Despliegue en Móvil
      • Diseño UX/UI para Móviles
    • Diseño Gráfico y Arte Digital
      • Fundamentos del Diseño Gráfico y Digital
      • Diseño de Identidad Visual y Branding
      • Ilustración Digital y Arte Conceptual
      • Diseño Editorial y de Empaques
      • Motion Graphics y Animación 3D
      • Diseño Gráfico Asistido por Inteligencia Artificial
      • Creatividad e Innovación en Diseño
    • Programación
      • Fundamentos de Programación e Ingeniería de Software
      • Herramientas de IA para el trabajo
      • Matemáticas para Programación
      • Programación con Python
      • Programación con JavaScript
      • Programación con TypeScript
      • Programación Orientada a Objetos con Java
      • Desarrollo con C# y .NET
      • Programación con PHP
      • Programación con Go y Rust
      • Programación Móvil con Swift y Kotlin
      • Programación con C y C++
      • Administración Básica de Servidores Linux
    • Negocios
      • Fundamentos de Negocios y Emprendimiento
      • Estrategia y Crecimiento Empresarial
      • Finanzas Personales y Corporativas
      • Inversión en Mercados Financieros
      • Ventas, CRM y Experiencia del Cliente
      • Operaciones, Logística y E-commerce
      • Gestión de Proyectos y Metodologías Ágiles
      • Aspectos Legales y Cumplimiento
      • Habilidades Directivas y Crecimiento Profesional
      • Diversidad e Inclusión en el Entorno Laboral
      • Herramientas Digitales y Automatización para Negocios
    • Blockchain y Web3
      • Fundamentos de Blockchain y Web3
      • Desarrollo de Smart Contracts y dApps
      • Finanzas Descentralizadas (DeFi)
      • NFTs y Economía de Creadores
      • Seguridad Blockchain
      • Ecosistemas Blockchain Alternativos (No-EVM)
      • Producto, Marketing y Legal en Web3
    • Recursos Humanos
      • Fundamentos y Cultura Organizacional en RRHH
      • Atracción y Selección de Talento
      • Cultura y Employee Experience
      • Gestión y Desarrollo de Talento
      • Desarrollo y Evaluación de Liderazgo
      • Diversidad, Equidad e Inclusión
      • AI y Automatización en Recursos Humanos
      • Tecnología y Automatización en RRHH
    • Finanzas e Inversiones
      • Fundamentos de Finanzas Personales y Corporativas
      • Análisis y Valoración Financiera
      • Inversión y Mercados de Capitales
      • Finanzas Descentralizadas (DeFi) y Criptoactivos
      • Finanzas y Estrategia para Startups
      • Inteligencia Artificial Aplicada a Finanzas
      • Domina Excel
      • Financial Analyst
      • Conseguir trabajo en Finanzas e Inversiones
    • Startups
      • Fundamentos y Validación de Ideas
      • Estrategia de Negocio y Product-Market Fit
      • Desarrollo de Producto y Operaciones Lean
      • Finanzas, Legal y Fundraising
      • Marketing, Ventas y Growth para Startups
      • Cultura, Talento y Liderazgo
      • Finanzas y Operaciones en Ecommerce
      • Startups Web3 y Blockchain
      • Startups con Impacto Social
      • Expansión y Ecosistema Startup
    • Cloud Computing y DevOps
      • Fundamentos de Cloud y DevOps
      • Administración de Servidores Linux
      • Contenerización y Orquestación
      • Infraestructura como Código (IaC) y CI/CD
      • Amazon Web Services
      • Microsoft Azure
      • Serverless y Observabilidad
      • Certificaciones Cloud (Preparación)
      • Plataforma Cloud GCP

    Platzi y comunidad

    • Platzi Business
    • Live Classes
    • Lanzamientos
    • Executive Program
    • Trabaja con nosotros
    • Podcast

    Recursos

    • Manual de Marca

    Soporte

    • Preguntas Frecuentes
    • Contáctanos

    Legal

    • Términos y Condiciones
    • Privacidad
    • Tyc promociones
    Reconocimientos
    Reconocimientos
    Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
    Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
    Logo reconocimientoPrimera Startup EdTech · 2018
    Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
    Logo reconocimientoCEO Mejor Emprendedor del año · 2024
    De LATAM conpara el mundo
    YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads