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
  • 2
    Prerrequisitos

    Prerrequisitos

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

    ¿Qué es una API?

    04:22
  • 4
    ¿Qué es REST?

    ¿Qué es REST?

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

    Creando tu primera API con .NET

    04:04
Funcionamiento de una API en .NET
  • 6
    Consumiendo API desde Postman

    Consumiendo API desde Postman

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

    Análisis del template para APIs de .NET

    10:51
  • 8
    Atributos para verbos HTTP

    Atributos para verbos HTTP

    14:56
  • 9
    Manejo de rutas

    Manejo de rutas

    09:51
  • 10
    Minimal API vs. Web API

    Minimal API vs. Web API

    08:36
Arquitectura y configuración
  • 11
    ¿Qué son los middlewares?

    ¿Qué son los middlewares?

    08:54
  • 12
    Creando un nuevo middleware

    Creando un nuevo middleware

    14:46
  • 13
    Inyección de dependencias

    Inyección de dependencias

    16:43
  • 14
    Agregando Logging a API

    Agregando Logging a API

    09:25
  • 15
    Documentando API con Swagger

    Documentando API con Swagger

    08:03
Manipulación de datos con Entity Framework
  • 16
    Agregando librerías para Entity Framework

    Agregando librerías para Entity Framework

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

    Configuración de Entity framework y clases base

    08:31
  • 18
    Creación de servicios

    Creación de servicios

    12:24
  • 19
    Inyectando servicios como dependencia

    Inyectando servicios como dependencia

    04:43
  • 20
    Creando controladores

    Creando controladores

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

    Probando API con una base de datos SQL server

    14:03
Outro
  • 22
    Retrospectiva: APIs con .NET

    Retrospectiva: APIs con .NET

    03:05
    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 3 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 2 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 un año

    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 un año

    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