<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Christian Sánchez</title>
    <description>The latest articles on DEV Community by Christian Sánchez (@christian_sc96).</description>
    <link>https://dev.to/christian_sc96</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F546705%2F761f4f04-f988-4c2a-aeaf-3007ee32afc7.jpg</url>
      <title>DEV Community: Christian Sánchez</title>
      <link>https://dev.to/christian_sc96</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/christian_sc96"/>
    <language>en</language>
    <item>
      <title>Autenticación, ¿qué es?</title>
      <dc:creator>Christian Sánchez</dc:creator>
      <pubDate>Thu, 21 Apr 2022 23:19:07 +0000</pubDate>
      <link>https://dev.to/christian_sc96/autenticacion-que-es-59af</link>
      <guid>https://dev.to/christian_sc96/autenticacion-que-es-59af</guid>
      <description>&lt;p&gt;Muchas veces cuando hablamos de autenticación es un poco complejo y más aún cuando nos toca dar el significado en sí del término y solemos confundir los significados con autorización. Prácticamente que al autenticarnos estamos demostrando quienes decimos ser. Pero hoy en día todos manejamos de memoria el trámite común para autenticar a uno o más usuarios en nuestras aplicaciones. Es el método de la vieja escuela de registrar un usuario con su información básica, como correo electrónico, contraseña, etc. y luego, en el momento del inicio de sesión, haga coincidir el correo electrónico y la contraseña proporcionados con los datos almacenados previamente.&lt;/p&gt;

&lt;p&gt;Pero actualmente han surgido varias herramientas o que han sido de gran ayuda para desarrollar estas formas de autenticarnos, y unos de mis pensamientos que un ingeniero de software realmente nunca para de aprender y en este mundo tan cambiante debemos prepararnos a dichos cambios y así mantenernos valiosos como desarrollador.&lt;/p&gt;

&lt;p&gt;Menciono a algunos métodos de validación de identidad de un usuario:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;Autenticación basada en sesión: Este método básicamente sucede cuando el usuario ingresa su nombre de usuario y contraseña y la solicitud pasa de la aplicación cliente al servidor, entonces el servidor busca al usuario, lo autentica y envía un token único a la aplicación cliente del usuario . (también guarda este token único en la memoria o en la base de datos).&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Autenticación basada en token:Usualmente lo aplicamos cuando el usuario ingresa sus credenciales de inicio de sesión, luego el servidor verifica que las credenciales sean correctas y devuelve un token firmado (el JWT) que puede contener información adicional como metadatos como user_id, permisos.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Autenticación Sin contraseña: Así como lo lee sin contraseña, alguna aplicación que haga eso, conozco una se llama streamyard. Las formas más populares para autenticarnos sin contraseñas son las siguientes: enviar un enlace único al correo electrónico o enviar un código o una contraseña única a través de SMS.&lt;br&gt;
Autenticación con una red social. Este método se ha vuelto muy popular, iniciar sesión con Google o Facebook por ejemplo.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Autenticación de dos factores: Este método realmente nos ayuda a proporcionar una capa adicional en la parte de seguridad para validar identidades en nuestras aplicaciones.&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;3 formas para autenticar un usuario: JWT, Firebase Auth o Auth0.&lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--9h5bIqZN--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/2vppjio5tavmzl94qk0y.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--9h5bIqZN--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/2vppjio5tavmzl94qk0y.png" alt="Image description" width="880" height="465"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Primero JWT (por sus siglas en ingles JSON Web Token) este es conocido como un estándar que define una manera segura de transmitir información a través de JSON.&lt;/p&gt;

&lt;p&gt;Luego encontramos Firebase Authentication, este es un servicio que ofrece Google y proporciona servicios de backend, fáciles de usar y bibliotecas de IU para autenticar a los usuarios en nuestros proyectos.&lt;/p&gt;

&lt;p&gt;Y por último, se encuentra Auth0, esta es una plataforma que te ayuda a autenticar y a autorizar, y tiene un cliente para poderlo usar con tecnologías .NET, Python entre otros. Y buen punto a recalcar es que he mencionado dos palabras claves que son “Autenticar” y “Autorizar”.&lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--bdQuC1iS--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/kywklcn5ls774hqmvw6w.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--bdQuC1iS--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/kywklcn5ls774hqmvw6w.png" alt="Image description" width="880" height="660"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Básicamente al autenticarnos estamos realizando el proceso de verificación de quiénes somos dentro de una aplicación usted, entonces en palabras más simples cuando inicia sesión en una aplicación con un nombre de usuario y contraseña, se está autenticando. Ahora bien la autorización es el procedimiento de verificación de los accesos que tenemos disponible dentro de una aplicación.&lt;/p&gt;

&lt;p&gt;No olvidemos autenticar a nuestros usuarios de manera segura.&lt;/p&gt;

</description>
    </item>
  </channel>
</rss>
