<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	
	xmlns:georss="http://www.georss.org/georss"
	xmlns:geo="http://www.w3.org/2003/01/geo/wgs84_pos#"
	>

<channel>
	<title>NodeJS &#8211; Oscar Blancarte &#8211; Software Architecture</title>
	<atom:link href="https://www.oscarblancarteblog.com/tag/nodejs/feed/" rel="self" type="application/rss+xml" />
	<link>https://www.oscarblancarteblog.com</link>
	<description>Software Architect &#38; FullStack developer</description>
	<lastBuildDate>Fri, 17 Jul 2020 01:14:17 +0000</lastBuildDate>
	<language>es-MX</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=5.5.13</generator>

<image>
	<url>https://www.oscarblancarteblog.com/wp-content/uploads/2019/03/cropped-ob-32x32.png</url>
	<title>NodeJS &#8211; Oscar Blancarte &#8211; Software Architecture</title>
	<link>https://www.oscarblancarteblog.com</link>
	<width>32</width>
	<height>32</height>
</image> 
<site xmlns="com-wordpress:feed-additions:1">89905023</site>	<item>
		<title>Javascript se está comiendo el mundo [VIDEO]</title>
		<link>https://www.oscarblancarteblog.com/2018/08/19/javascript-se-esta-comiendo-mundo-video/</link>
					<comments>https://www.oscarblancarteblog.com/2018/08/19/javascript-se-esta-comiendo-mundo-video/#respond</comments>
		
		<dc:creator><![CDATA[oblancarte]]></dc:creator>
		<pubDate>Mon, 20 Aug 2018 02:33:25 +0000</pubDate>
				<category><![CDATA[Javascript]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[mongodb]]></category>
		<category><![CDATA[NodeJS]]></category>
		<category><![CDATA[react]]></category>
		<guid isPermaLink="false">https://www.oscarblancarteblog.com/?p=2254</guid>

					<description><![CDATA[<p>Es impresionante pensar como JavaScript, un lenguaje desarrollados en los 80’s con el único objetivo proporcionar validaciones de formularios y alertas a los usuarios, se ha convertido en el lenguaje de programación más utilizado en el mundo, sobre pasando a lenguajes tan populares como Java o Python y ejecutándose prácticamente en todos lados, desde FrontEnd, [&#8230;]</p>
<p>The post <a rel="nofollow" href="https://www.oscarblancarteblog.com/2018/08/19/javascript-se-esta-comiendo-mundo-video/">Javascript se está comiendo el mundo [VIDEO]</a> appeared first on <a rel="nofollow" href="https://www.oscarblancarteblog.com">Oscar Blancarte - Software Architecture</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p>				<iframe class='youtube-player' width='648' height='365' src='https://www.youtube.com/embed/JrAFUc4LkCE?version=3&#038;rel=1&#038;fs=1&#038;autohide=2&#038;showsearch=0&#038;showinfo=1&#038;iv_load_policy=1&#038;wmode=transparent' allowfullscreen='true' style='border:0;'></iframe></p>
<p>Es impresionante pensar como JavaScript, un lenguaje desarrollados en los 80’s con el único objetivo proporcionar validaciones de formularios y alertas a los usuarios, se ha convertido en el lenguaje de programación más utilizado en el mundo, sobre pasando a lenguajes tan populares como Java o Python y ejecutándose prácticamente en todos lados, desde FrontEnd, BackEnd y Dispositivos Móviles.		</p>
<p>The post <a rel="nofollow" href="https://www.oscarblancarteblog.com/2018/08/19/javascript-se-esta-comiendo-mundo-video/">Javascript se está comiendo el mundo [VIDEO]</a> appeared first on <a rel="nofollow" href="https://www.oscarblancarteblog.com">Oscar Blancarte - Software Architecture</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://www.oscarblancarteblog.com/2018/08/19/javascript-se-esta-comiendo-mundo-video/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">2254</post-id>	</item>
		<item>
		<title>Implementar JSON Web Tokens con NodeJS</title>
		<link>https://www.oscarblancarteblog.com/2018/01/16/implementar-json-web-tokens-nodejs/</link>
					<comments>https://www.oscarblancarteblog.com/2018/01/16/implementar-json-web-tokens-nodejs/#comments</comments>
		
		<dc:creator><![CDATA[oblancarte]]></dc:creator>
		<pubDate>Tue, 16 Jan 2018 10:00:32 +0000</pubDate>
				<category><![CDATA[NodeJS]]></category>
		<category><![CDATA[express]]></category>
		<category><![CDATA[jwt]]></category>
		<guid isPermaLink="false">https://www.oscarblancarteblog.com/?p=2003</guid>

					<description><![CDATA[<p>JSON Web Tokens o simplemente JTW, es una herramienta que nos permite autenticarnos con el servidor mediante Tokens de una forma simple y segura. Los Tokens son una cadena de alfanumérica, que es generada por el servidor y es enviada al cliente para autenticaciones futuras, evitando tener que enviar credenciales en cada invocación. Te recomiendo [&#8230;]</p>
<p>The post <a rel="nofollow" href="https://www.oscarblancarteblog.com/2018/01/16/implementar-json-web-tokens-nodejs/">Implementar JSON Web Tokens con NodeJS</a> appeared first on <a rel="nofollow" href="https://www.oscarblancarteblog.com">Oscar Blancarte - Software Architecture</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p>				<img loading="lazy" class="aligncenter size-full wp-image-2009" src="https://www.oscarblancarteblog.com/wp-content/uploads/2018/01/implementando-JSON-Web-Tokens-con-NodeJS-Cuarta-parte.png" alt="implementando JSON Web Tokens con NodeJS - Cuarta parte" width="724" height="406" />JSON Web Tokens o simplemente JTW, es una herramienta que nos permite autenticarnos con el servidor mediante Tokens de una forma simple y segura. Los Tokens son una cadena de alfanumérica, que es generada por el servidor y es enviada al cliente para autenticaciones futuras, evitando tener que enviar credenciales en cada invocación.<span id="more-2003"></span></p>
<p><em>Te recomiendo que te des una venta a mi artículo <a href="https://www.oscarblancarteblog.com/2017/06/08/autenticacion-con-json-web-tokens/"><strong>Autenticación con JSON Web Tokens</strong></a>, el cual abordo toda la teoría, por si no estás familiarizado con el concepto de Tokens y la forma de trabajar.</em></p>
<p><em>Este artículo es parte de una colección de artículo en donde explico cómo <a href="https://www.oscarblancarteblog.com/2018/01/11/construir-api-rest-nodejs-primera-parte/"><strong>Construir un API REST con NodeJS</strong></a>, por lo que si estas interesado puede regresar desde el comienzo.</em></p>
<h2>Implementando JWT en un API REST</h2>
<p>Lo primero será instalar el módulo de JWT, para lo cual, ejecutaremos el comando <span class="lang:default decode:true crayon-inline">npm install &#8211;save jsonwebtoken body-parser</span> , una vez hecho esto, tendremos que implementar un servicio de autenticación tradicional, el cual reciba usuario y contraseña y nos regrese un token en caso de éxito. El servicio quedaría de la siguiente manera:</p>
<pre class="lang:js decode:true ">var jwt = require('jsonwebtoken')
var bodyParser = require('body-parser')

app.use(bodyParser.urlencoded({extended: false}))
app.use(bodyParser.json({limit:'10mb'}))

app.post('/login', (req, res) =&gt; {
  var username = req.body.user
  var password = req.body.password

  if( !(username === 'oscar' &amp;&amp; password === '1234')){
    res.status(401).send({
      error: 'usuario o contraseña inválidos'
    })
    return
  }

  var tokenData = {
    username: username
    // ANY DATA
  }

  var token = jwt.sign(tokenData, 'Secret Password', {
     expiresIn: 60 * 60 * 24 // expires in 24 hours
  })

  res.send({
    token
  })
})</pre>
<p>La función login recibe como parámetro el usuario (<span class="lang:default decode:true crayon-inline ">req.body.user</span> ) y el password (<span class="lang:default decode:true crayon-inline ">req.body.password</span> ), los cuales los tendremos que validar contra nuestros usuarios, sin embargo, en este caso, para hacerlo más simple, lo hemos validado contra el usuario oscar/1234, si la autenticación falla, entonces regresamos un error al cliente. Por otra parte, si todo sale bien, creamos un token al usuario, el cual tiene una vigencia de 24 horas, para finalmente retornarlo.</p>
<p>Veamos un ejemplo de autenticación:</p>
<p><img loading="lazy" class="aligncenter size-full wp-image-2004" src="https://www.oscarblancarteblog.com/wp-content/uploads/2018/01/Creando-el-Token-JWS.png" alt="Creando el Token JWS" width="938" height="762" /></p>
<p>En la imagen pasada hemos enviado las credenciales correctas para que nos genere un token, sin embargo, no se puede ver correctamente debido a su longitud, es por ello que lo ponemos por a continuación:</p>
<pre class="lang:js decode:true">{
"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6Im9zY2FyIiwiaWF0IjoxNTE2MDY4OTI4LCJleHAiOjE1MTYxNTUzMjh9.zucLW085AiZ8VWojwNFFcMz0yv1H4RbeCMQy7lVjS7s"
}</pre>
<p>Este token deberá ser guardado por el usuario para futuras invocaciones al API.</p>
<h2>Autenticándonos mediante Tokens</h2>
<p>El siguiente paso será crear un servicio protegido que valida la existencia del token, de lo contrario, evitará el acceso, para ello crearemos un servicio de prueba llamado secure:</p>
<pre class="lang:js decode:true">app.get('/secure', (req, res) =&gt; {
    var token = req.headers['authorization']
    if(!token){
        res.status(401).send({
          error: "Es necesario el token de autenticación"
        })
        return
    }

    token = token.replace('Bearer ', '')

    jwt.verify(token, 'Secret Password', function(err, user) {
      if (err) {
        res.status(401).send({
          error: 'Token inválido'
        })
      } else {
        res.send({
          message: 'Awwwww yeah!!!!'
        })
      }
    })
})</pre>
<p>Como podemos observar, lo primero que tenemos que hacer, es recuperar el header correspondiente al token, es decir, el token “<span class="lang:default decode:true crayon-inline ">authorization</span> ”, si este header no se encuentra, entonces retornamos un código 401 (No autorizado) y regresamos el motivo del error.</p>
<p>El siguiente paso es algo confuso, pues al token hay que retirarla el substring “<span class="lang:default decode:true crayon-inline ">Baerer </span> “, este String es parte de las especificaciones de HTTP, y es agredo de forma automática, por lo que no entraremos en detalles, simplemente lo retiramos.</p>
<p>Finalmente, validamos el token mediante el método verify, el cual validará que el token sea válido y además que no esté caducado, en cualquiera de estos dos casos, un error 401 es retornado junto con el mensaje de error. Finalmente, si todo sale bien, procedemos con la operación de negocio.</p>
<p>El siguiente request es enviado son el header, retornando un error 401 y su mensaje de error correspondiente:</p>
<p><img loading="lazy" class="aligncenter size-full wp-image-2005" src="https://www.oscarblancarteblog.com/wp-content/uploads/2018/01/Validacion-fallida-del-token-JWT.png" alt="Validacion fallida del token JWT" width="926" height="651" /></p>
<p>Este nuevo request es enviado con el header ‘<span class="lang:default decode:true crayon-inline ">authorization</span> ’ el cual corresponde a un token válido generado por el servicio de login:<img loading="lazy" class="aligncenter size-full wp-image-2006" src="https://www.oscarblancarteblog.com/wp-content/uploads/2018/01/Validacion-exitosa-del-token-JWT.png" alt="" width="926" height="661" /></p>
<p>NOTA: Siempre será mejor usar un middleware para validar el token, de esta forma, evitamos tener que validar el token en cada invocación, sin embargo, lo hemos hecho así para hacer más fácil el ejemplo.		</p>
<p>The post <a rel="nofollow" href="https://www.oscarblancarteblog.com/2018/01/16/implementar-json-web-tokens-nodejs/">Implementar JSON Web Tokens con NodeJS</a> appeared first on <a rel="nofollow" href="https://www.oscarblancarteblog.com">Oscar Blancarte - Software Architecture</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://www.oscarblancarteblog.com/2018/01/16/implementar-json-web-tokens-nodejs/feed/</wfw:commentRss>
			<slash:comments>12</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">2003</post-id>	</item>
		<item>
		<title>Construir un API REST con NodeJS (Tercera parte)</title>
		<link>https://www.oscarblancarteblog.com/2018/01/15/construir-api-rest-nodejs-tercera-parte/</link>
					<comments>https://www.oscarblancarteblog.com/2018/01/15/construir-api-rest-nodejs-tercera-parte/#comments</comments>
		
		<dc:creator><![CDATA[oblancarte]]></dc:creator>
		<pubDate>Mon, 15 Jan 2018 10:00:42 +0000</pubDate>
				<category><![CDATA[NodeJS]]></category>
		<category><![CDATA[API REST]]></category>
		<category><![CDATA[express]]></category>
		<guid isPermaLink="false">https://www.oscarblancarteblog.com/?p=1989</guid>

					<description><![CDATA[<p>Este artículo es la tercera parte del articulo original (Segunda parte), en la cual hablamos de los HTTP Verbs, su importancia, funcionalidad y cómo implementarla en nuestro API utilizando NodeJS + Express. En esta tercera parte, hablaremos acerca de los URL paths, cómo es posible crear URL parametrizadas y la forma de recuperar los parámetros [&#8230;]</p>
<p>The post <a rel="nofollow" href="https://www.oscarblancarteblog.com/2018/01/15/construir-api-rest-nodejs-tercera-parte/">Construir un API REST con NodeJS (Tercera parte)</a> appeared first on <a rel="nofollow" href="https://www.oscarblancarteblog.com">Oscar Blancarte - Software Architecture</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p>				<img loading="lazy" class="aligncenter size-full wp-image-1991" src="https://www.oscarblancarteblog.com/wp-content/uploads/2018/01/banner.png" alt="Construir un API REST con NodeJS - Tercera parte" width="723" height="404" />Este artículo es la tercera parte del articulo original (<a href="https://www.oscarblancarteblog.com/2018/01/12/construir-api-rest-nodejs-segunda-parte/">Segunda parte</a>), en la cual hablamos de los HTTP Verbs, su importancia, funcionalidad y cómo implementarla en nuestro API utilizando <a href="https://www.oscarblancarteblog.com/2017/05/29/introduccion-a-nodejs-2/">NodeJS</a> + Express. En esta tercera parte, hablaremos acerca de los URL paths, cómo es posible crear URL parametrizadas y la forma de recuperar los parámetros del objeto request.<span id="more-1989"></span></p>
<h2>URL Paths</h2>
<p>Uno de los aspectos más importantes de un servicio REST, es su URL, primero que nada, porque es la <strong>forma en que podemos consumir el servicio</strong>, pero también es importante por le da al usuario una <strong>pista significativa acerca de su funcionalidad</strong>. Una URL bien definida, podría decirle al usuario para que sirve con una precisión muy acertada, sin tener que recurrir a la documentación.</p>
<p>Para que una URL tenga un significado real, es necesario complementarlo con método (o verb) al que responde, pues el método nos dice el tipo de operación que va a realizar, mientras que la URL nos dice que es lo que va hacer. Analicemos las siguientes URL:</p>
<table  class=" table table-hover" >
<tbody>
<tr>
<td width="75">GET</td>
<td width="491">/users/oscar/avatar</td>
</tr>
<tr>
<td width="75">PUT</td>
<td width="491">/users/oscar/avatar</td>
</tr>
<tr>
<td width="75">DELETE</td>
<td width="491">/users/oscar</td>
</tr>
<tr>
<td width="75">POST</td>
<td width="491">/users</td>
</tr>
</tbody>
</table>
<p>Quiero que te tomes solo un momento para analizar las URL anteriores… te aseguro que sin ser un experto pudiste adivinar con gran certeza que hace cada una de estas operaciones. Si no, te recomiendo ver la segunda parte de este artículo para refrescar un poco la memoria.</p>
<p>Como sea, vamos a explicar que hace cada una, en la primera URL, sabemos que el GET se utiliza para consultas y la URL habla de usuarios, luego un nombre y finalmente un avatar, por lo que podemos deducir que este servicio está realizando la consulta del Avatar del usuario oscar, ¿vez que fácil?</p>
<p>En la segunda URL, sabemos que PUT se utiliza para realizar updates, por lo tanto, le estamos diciendo que actualice el Avatar del usuario oscar.</p>
<p>En la tercera URL, sabemos que DELETE se utiliza para borrar un registro, por lo que está de más decir que lo que hace es borrar el usuario oscar.</p>
<p>En la cuarta URL, sabemos que POST se utiliza para crear un nuevo registro y está invocando solamente <em>/users</em>, esto me dice que el servicio está creando un nuevo usuario.</p>
<p>Con Express es realmente fácil implementar estas URL, tan solo hay que definir los Routers con el método adecuado y con el URL al que debe procesar, veamos cómo quedaría:</p>
<pre class="lang:js decode:true">app.get('/users/oscar/avatar', (req, res) =&gt; {
  res.send('Hello GET:/users/oscar/avatar')
})

app.put('/users/oscar/avatar', (req, res) =&gt; {
  res.send('Hello PUT:/users/oscar/avatar')
})

app.delete('/users/oscar', (req, res) =&gt; {
  res.send('Hello DELETE:/users/oscar')
})

app.post('/users', (req, res) =&gt; {
  res.send('Hello POST:/users')
})</pre>
<p>Los paths siempre deben de representar exactamente lo que hacen, y el método debe de corresponder con la acción que realizará, pues no hacerlo, puede confundir a los desarrolladores.</p>
<h2>Prioridad de los paths</h2>
<p>Un error al momento de iniciar con Express es pensar que el orden en que se definen los Routers es irrelevante, como si de una función se tratara, la cual puede ser llamada desde donde sea y siempre se ejecuta la correcta, sin embargo, esto no es cierto. Por este motivo, Express evaluar los Router en el orden en que están definidos.</p>
<p>Existe ocasiones en que más de una URL puede colisionar y entrar en el Path equivocado, por ejemplo, las siguientes dos URL:</p>
<p><span class="lang:default decode:true crayon-inline">GET: /*</span></p>
<p><span class="lang:default decode:true crayon-inline ">GET:/login</span></p>
<p>La primera acepta cualquier URL, porque tiene un comodín (*), mientras que la segunda, solo acepta la URL <em>/login</em>. En este caso, como <em>/*</em> esta primero, entonces atenderá las peticiones que lleguen a <em>/login</em>, porque el path <em>/*</em> cumple con el patrón, en tal caso, tendríamos que invertir el orden de los Routers de la siguiente manera:</p>
<p><span class="lang:default decode:true crayon-inline ">GET:/login </span></p>
<p><span class="lang:default decode:true crayon-inline ">GET: /* </span></p>
<p>De esta forma, cuando llegue una petición a <em>/login</em>, la tomará el primer Router y para todos los demás path será <em>/*</em> quien procese la solicitud.</p>
<h2>URL Params</h2>
<p>Una de las características de REST, es la posibilidad de convertir ciertas partes de una URL en parámetro, de tal forma que nos ahorra tener que escribir una URL para cada registro que necesitemos.</p>
<p>Regresando al ejemplo de los servicios para usuarios GET: <em>/users/oscar</em>, podemos apreciar que “oscar” esta fija en la URL, lo que provocaría que tuviéramos que tener un Router para cada usuario registrado. Por suerte, Express nos permite escribir URL Params. Para convertir una sección de la URL en URL param, solo tendremos que anteponer dos puntos (:) antes, por ejemplo:</p>
<p><span class="lang:default decode:true crayon-inline ">/users/:username </span></p>
<p><span class="lang:default decode:true crayon-inline ">/users/:username/:field </span></p>
<p>En la primera URL podríamos recibir consultas para todos los usuarios, por ejemplo:</p>
<p><span class="lang:default decode:true crayon-inline ">/users/oscar</span> , <span class="lang:default decode:true crayon-inline ">/users/juan</span> , <span class="lang:default decode:true crayon-inline ">/users/pedro</span></p>
<p>Mientras que en la segunda URL podríamos consultar cualquier campo del usuario, por ejemplo:</p>
<p><span class="lang:default decode:true crayon-inline ">/users/oscar/avatar</span>  o <span class="lang:default decode:true crayon-inline ">/users/juan/banner</span></p>
<p>Para recuperar los URL Params, tan solo es necesario recuperarlos del objeto request de la siguiente manera: <em>req.params.&lt;name&gt;</em>. Veamos algunos ejemplos:</p>
<p><img loading="lazy" class="aligncenter wp-image-1993" src="https://www.oscarblancarteblog.com/wp-content/uploads/2018/01/API-REST-url-params.png" alt="API REST - URL Params" width="921" height="220" /></p>
<h2></h2>
<h2>Query params</h2>
<p>Los query params son lo más conocidas, y son todos aquellos que van al final de la URL seguido del símbolo de interrogación (?). Se pueden enviar cuantos Query params se requiere, siempre y cuando no excedamos el límite máximo de caracteres para un URL. Cada parámetro deberá está separado un el símbolo de ampersand (&amp;). Algunos ejemplos:</p>
<p><span class="lang:default decode:true crayon-inline ">/cources?coupon=FREE&amp;Source=Google</span></p>
<p>Este tipo de parámetros es muy común en campañas publicitarias, pues el param coupon determina que el curso a comprar es gratis (free), mientras que el param Source nos dice de donde llego el cliente (google).</p>
<p>Para recuperar un Query param en Express se usa la siguiente sentencia, <em>req.query.&lt;parama-name&gt;</em>. Veamos cómo implementarlo en Express.</p>
<pre class="lang:js decode:true ">app.get('/cources', (req, res) =&gt; {
  var coupon = req.query.coupon
  var source = req.query.source
  res.send("Coupo: " + coupon + ", Source: " + source)
})</pre>
<p>Si ejecutamos la URL <em>/cources?coupon=FREE&amp;Source=Google</em>  obtendremos el siguiente resultado:</p>
<p><img loading="lazy" class="aligncenter size-full wp-image-1994" src="https://www.oscarblancarteblog.com/wp-content/uploads/2018/01/query-params.png" alt="API REST - query params" width="733" height="293" /></p>
<figure id="attachment_2293" aria-describedby="caption-attachment-2293" style="width: 648px" class="wp-caption aligncenter"><a href="https://reactiveprogramming.io/books/applicaciones-reactivas-con-react-nodejs-mongodb" target="_blank" rel="noopener"><img loading="lazy" class="wp-image-2293 size-large" src="https://www.oscarblancarteblog.com/wp-content/uploads/2017/11/react-banner-1024x394.jpg" alt="" width="648" height="249" /></a><figcaption id="caption-attachment-2293" class="wp-caption-text">¿Te gustaría aprender las técnicas más avanzadas para crear API REST con NodeJS? Te invito a que veas mi libro “Aplicaciones reactivas con React, NodeJS &amp; MongoDB”, donde aprenderás a crear una API REST completo, desde exponer los servicios hasta habilitar la seguridad con JSON Web Token (JTW)</figcaption></figure>
<h2>Body params</h2>
<p>El tercer y último tipo de parámetro que podemos enviarle a un servicio REST, es el payload (o body), el cual puede ser un mensaje largo que no se puede ver a simple vista. No todos los métodos HTTP soportan el envío de un payload, por lo que hay que tener eso en cuenta.</p>
<p>De los métodos más utilizados que soportan el envío de un payload son: POST, PUT, PATCH, DELETE. Observa que el método GET no lo soporta.</p>
<p>Recuperar el body del request no está simple como parecería, pues en realidad, este parámetro es un InputStream, lo que quiere decir, que se recibe como los datos poco a poco y no todo de una. Esto nos obliga a procesar el payload a medida que va llegando. Este proceso lo podemos simplificar con ayuda del módulo body-parser, el cual instalamos en la primera parte de este artículo (<em>npm install &#8211;save body-parser</em>).</p>
<p>Mediante este módulo, es posible convertir el payload en varios formatos, pero el que nos interesa es JSON, pues es el estándar para REST. Configurarlo, solo tendremos que importarlo y agregar un middleware (los analizaremos más adelante).</p>
<p><img loading="lazy" class="aligncenter wp-image-1995 size-full" src="https://www.oscarblancarteblog.com/wp-content/uploads/2018/01/API-REST-Body-param.png" alt="API REST - Body param" width="925" height="734" /></p>
<p>Finalmente, existe una última forma de recibir información para el API, la cual es a través de Header, sin embargo, esta parte la dejaremos para la siguiente parte, en la cual hablaremos de la autenticación mediante JSON Web Tokens (JWT).		</p>
<p>The post <a rel="nofollow" href="https://www.oscarblancarteblog.com/2018/01/15/construir-api-rest-nodejs-tercera-parte/">Construir un API REST con NodeJS (Tercera parte)</a> appeared first on <a rel="nofollow" href="https://www.oscarblancarteblog.com">Oscar Blancarte - Software Architecture</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://www.oscarblancarteblog.com/2018/01/15/construir-api-rest-nodejs-tercera-parte/feed/</wfw:commentRss>
			<slash:comments>16</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">1989</post-id>	</item>
		<item>
		<title>Autenticación con JSON Web Tokens</title>
		<link>https://www.oscarblancarteblog.com/2017/06/08/autenticacion-con-json-web-tokens/</link>
					<comments>https://www.oscarblancarteblog.com/2017/06/08/autenticacion-con-json-web-tokens/#comments</comments>
		
		<dc:creator><![CDATA[oblancarte]]></dc:creator>
		<pubDate>Thu, 08 Jun 2017 10:00:51 +0000</pubDate>
				<category><![CDATA[JSON]]></category>
		<category><![CDATA[NodeJS]]></category>
		<category><![CDATA[Seguridad]]></category>
		<category><![CDATA[javascript]]></category>
		<guid isPermaLink="false">https://www.oscarblancarteblog.com/?p=1732</guid>

					<description><![CDATA[<p>Los JSON Web Tokens (JWT) se ha convertido rápidamente en un estándar en la autenticación de aplicaciones, pues permite de una forma simple y elegante identificarte con el servidor mediante un Token. Dicho token es generado por el servidor y es transmitido hacia el cliente, el cual deberá presentar en cada invocación para poder ser [&#8230;]</p>
<p>The post <a rel="nofollow" href="https://www.oscarblancarteblog.com/2017/06/08/autenticacion-con-json-web-tokens/">Autenticación con JSON Web Tokens</a> appeared first on <a rel="nofollow" href="https://www.oscarblancarteblog.com">Oscar Blancarte - Software Architecture</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p><img loading="lazy" class="aligncenter size-full wp-image-1738" src="https://www.oscarblancarteblog.com/wp-content/uploads/2017/06/JSON-Web-Tokens.png" alt="JSON Web Tokens" width="1379" height="847" />Los JSON Web Tokens (JWT) se ha convertido rápidamente en un estándar en la autenticación de aplicaciones, pues permite de una forma simple y elegante identificarte con el servidor mediante un Token. Dicho token es generado por el servidor y es transmitido hacia el cliente, el cual deberá presentar en cada invocación para poder ser autenticado.<span id="more-1732"></span></p>
<h2>Que es un Token</h2>
<p>Lo primero que debemos de entender, es que es un token, pues será un concepto fundamental para entender el resto del artículo.</p>
<p>Un token es una cadena alfanumérica con caracteres aparentemente aleatorios, como el siguiente:</p>
<pre class="">eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiYWRtaW4iOnRydWV9.TJVA95OrM7E2cBab30RMHrHDcEfxjoYZgeFONFh7HgQ</pre>
<p>o el siguiente:</p>
<pre class="">24353689</pre>
<p>Estas cadenas de texto, pueden no aparentar un significado, sin embargo, tiene un significado real para el servidor o institución que lo emitió, el cual puede entender y así, validar al usuario que intenta acceder a la información, e incluso, puede tener datos adicionales.</p>
<p>Te dejo un video donde explico que es un Token:</p>
<p><iframe class='youtube-player' width='648' height='365' src='https://www.youtube.com/embed/CxeNGqZ_US8?version=3&#038;rel=1&#038;fs=1&#038;autohide=2&#038;showsearch=0&#038;showinfo=1&#038;iv_load_policy=1&#038;wmode=transparent' allowfullscreen='true' style='border:0;'></iframe></p>
<p>Un caso simple de tokens, es el dispositivo que dan los bancos para realizar transacciones desde internet, este token te genera un valor numérico que luego tenemos que ingresar al sistema, para que de esta forma, el portal pueda asegurarse de que efectivamente somos nosotros y no un impostor.</p>
<p><img loading="lazy" class="aligncenter wp-image-1733" src="https://www.oscarblancarteblog.com/wp-content/uploads/2017/06/bank-token.png" alt="" width="974" height="351" /></p>
<p>En el caso de los tokens bancarios, no se almacena una información real dentro del Token, sino que simplemente es un valor generado que luego puede ser validado por el banco como un valor real generado por nuestro token. Sin embargo, con JWT podemos enviar cualquier dato del cliente dentro del token para que el servidor pueda obtener mucha más información de nosotros.</p>
<h2>Que son los JSON Web Tokens</h2>
<p>Bien, una vez que comprendemos que son los Tokens podemos decir que los JWT son un tipo de token el cual engloba una estructura, la cual puede ser desencriptada por el servidor y de esta forma, autenticarnos como usuario en la aplicación.</p>
<p>Veamos la estructura de un JWT:</p>
<p><span style="color: #ff00ff;">eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9</span>.<span style="color: #00ccff;">eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiYWRtaW4iOnRydWV9</span>.<span style="color: #ff0000;">TJVA95OrM7E2cBab30RMHrHDcEfxjoYZgeFONFh7HgQ</span></p>
<p>Observemos que la cadena está dividida en 3 secciones separadas por un punto. Estas tres secciones tienen un significado:</p>
<ol>
<li><strong>HEADER:</strong> la primera parte, corresponde a los Header, y se almacena por lo general el tipo de token y el algoritmo de encriptamiento.</li>
<li><strong>PAYLOAD:</strong> La segunda parte, contiene los datos que identifican al usuario, como puede ser su ID, nombre de usuario, etc.</li>
<li><strong>FIRMA:</strong> La tercera parte es la firma digital, la cual se genera con las secciones anteriores y sirve para validar que el contenido no haya sido alterado.</li>
</ol>
<p>Ejemplo del Header</p>
<pre class="lang:js decode:true">{
  "alg": "HS256",
  "typ": "JWT"
}</pre>
<p>Ejemplo del Payload</p>
<pre class="lang:js decode:true ">{
  "id": "1234567890",
  "name": "Oscar Blancarte",
  "rol": “admin”
}</pre>
<p>La firma por otra parte es el header y el payload en base64 y después encriptado.</p>
<p>Puedes leer más de <a href="https://jwt.io/">JWT en su página oficial</a></p>
<h2>Como se utiliza los JWT</h2>
<p>Como ya hablamos, los JWT se utilizan para autenticar a los usuarios, para ello, el usuario requiere de un login tradicional como es el usuario y password. Una vez, que el sistema de Backend valida que el usuario y contraseña son correctos, este retorna un token al usuario. Este token lo deberá guardar el cliente, pues de aquí en adelante, todas las peticiones que realice al servidor, deberá llevar el token.</p>
<p><img loading="lazy" class="aligncenter wp-image-1734 " src="https://www.oscarblancarteblog.com/wp-content/uploads/2017/06/JWT-token.png" alt="JWT JSON Web Token" width="954" height="344" /></p>
<p>El token es por lo general almacenado en Cookies o en el LocalStorage del navegador, y cuando es requerido enviar un request al servidor, se recupere y se envía como header.</p>
<p>Un dato interesante del token es que no requiere que el servidor lo almacene para compararlos cuando lo envíe el cliente, pues el token por si solo puede ser auto validado, y como tiene un payload, es posible determinar de quien es el token. Veamos el siguiente payload:</p>
<pre class="lang:js decode:true ">{
  “userID”: 12345,
  “username”: “oblancarte”,
  “rol”: “admin”
}</pre>
<p>Cuando el servidor desencripte el token, podrá recuperar este payload y con ello, podrá saber que usuario es e incluso, es posible guardar datos adicionales como el rol o cualquier dato en formato JSON.</p>
<p>Otro dato interesante del token es que expira, es decir, el token solo es válido por un tiempo determinado. Por lo que el usuario deberá volverse a logear una vez que el token expire.</p>
<h2>Veamos cómo funcionaría todo el ciclo de vida de un JWT</h2>
<p>Ya hemos hablado de como JWT funciona, pero ahora entraremos a ver como es la interacción que tiene un usuario al autenticarse por medio de JWT, para lo cual veamos la siguiente imagen:</p>
<p><img loading="lazy" class="aligncenter wp-image-1735" src="https://www.oscarblancarteblog.com/wp-content/uploads/2017/06/JWT-lifecycle.png" alt="JWT JSON Web Token-lifecycle" width="917" height="407" /></p>
<p>Los pasos son los siguientes:</p>
<ol>
<li>El usuario requiere de una autenticación tradicional con el servidor, es decir usuario y password (o cualquier otro tipo de autenticación).</li>
<li>El servidor validará que los datos introducidos sean correctos y generará un Token.</li>
<li>El servidor enviará el token al usuario y este lo tendrá que almacenar de cualquier forma.</li>
<li>Una vez con el token, el usuario realiza una petición al servidor, enviando en el header el token previamente generado.</li>
<li>El servidor validará que el token sea correcto, desencriptandolo mediante la misma llave que utilizo para encriptarlo.</li>
<li>Si el token es correcto, entonces el servidor retornará los datos solicitados.</li>
</ol>
<p>Cabe mencionar que los puntos 4,5 y 6 se pueden repetir indeterminado número de veces hasta que el token caduque, cuando esto pase, entonces será necesario reiniciar desde el paso 1.</p>
<h2>Como implementar un JWT</h2>
<p>Existe una serie de librerías que nos permite crear un JWT, y todo dependerá del lenguaje que utilicemos. Sin embargo, quiero mostrarte como crear un JWT con <a href="https://www.oscarblancarteblog.com/2017/05/29/introduccion-a-nodejs-2/">NodeJS</a>.</p>
<p>Lo primero, es que será necesario importar el módulo <strong>jsonwebtoken:</strong></p>
<p><em>npm install –save jsonwebtoken</em></p>
<p><em> </em></p>
<h3>Generación del Token</h3>
<p>ya con la dependencia instalada podemos crear el token de la siguiente manera:</p>
<pre class="lang:js decode:true ">var jwt = require('jsonwebtoken')

function generateToken(user) {
  var u = {
   username: user.username,
   id: user.id
  }
  return token = jwt.sign(u, ‘password’, {
     expiresIn: 60 * 60 * 24 // expires in 24 hours
  })
}</pre>
<p>Lo primero que haremos será crear una función que reciba el objeto usuario o cualquier otro objeto que contenga la información requerida para la autenticación. Luego mediante el objeto usuario, creamos el objeto u, el cual solo contiene el username y el ID del usuario. Este objeto se convertirá en el payload del JWT, es decir la segunda parte del token.</p>
<p>Seguido, procedemos a crear el token mediante el módulo jwt, el cual nos proporciona el método sign que recibirá el payload y un password, este password deberá ser secreto, pues con él, podremos crear y desencriptar los tokens. Finalmente, el tercer parámetro son las opciones, aquí podremos seleccionar el algoritmo de encriptación, la fecha de expiración, etc.  En este ejemplo dejamos la configuración por default, pero agregamos que el token sea válidos solo por 24 horas.</p>
<p>Finalmente, el token es retornado al cliente.</p>
<h3>Validación del token</h3>
<p>Hasta este punto solo hemos visto la parte de la generación del Token, pero falta la segunda parte, en donde tenemos que validar que el Token que el cliente nos manda, es válido.</p>
<p>Para validar el Token podemos utilizar un Middleware de Express que valide de forma automática todas las URL que inicien con <strong>/secure</strong>. El middleware se ve de la siguiente manera:</p>
<pre class="lang:js decode:true ">router.use('/secure',function(req, res, next) {
  var token = req.headers['authorization']
  if (!token) {
    res.status(401).send({
      ok: false,
      message: 'Toket inválido'
    })
  }

  token = token.replace('Bearer ', '')

  jwt.verify(token, ‘password’, function(err, token) {
    if (err) {
      return res.status(401).send({
        ok: false,
        message: 'Toket inválido'
      });
    } else {
      req.token = token
      next()
    }
  });
});</pre>
<p>Podemos ver que en la primera llínea inicializa el middleware, luego en la segunda línea obtenemos el token del header <strong>“</strong><strong>authorization”</strong>. Si el token es Null regresamos un 401 indicando que no el cliente no tiene privilegios.</p>
<p>Los token generados por JWT se crean con la palabra “Bearer” al inicio del token, por lo que en la línea 10 quitamos esa parte del token, seguido, en la línea 12 realizamos la validación del token mediante el método verify.</p>
<p>Este método recibe el token como primer parámetro, como segundo parámetro, mandamos el password para desencriptar el token. Finalmente se envía como tercer parámetro una función Callback una vez que el token sea validado.</p>
<p>Si todo salió bien, el token estará en la variable token, en caso contrario, tendremos el error en la variable err.</p>
<h2>Conclusiones</h2>
<p>Como pudimos ver, los tokens son una magnifica forma de administrar la autenticación de los usuarios, pues permite crear de forma fácil, un mecanismo para comunicarse de forma segura entre el cliente y el servidor, además, de que permite mantener autenticado a un usuario por un tiempo determinado, evitando tener que iniciar sesión cada vez que entre a nuestra aplicación.</p>
<p>The post <a rel="nofollow" href="https://www.oscarblancarteblog.com/2017/06/08/autenticacion-con-json-web-tokens/">Autenticación con JSON Web Tokens</a> appeared first on <a rel="nofollow" href="https://www.oscarblancarteblog.com">Oscar Blancarte - Software Architecture</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://www.oscarblancarteblog.com/2017/06/08/autenticacion-con-json-web-tokens/feed/</wfw:commentRss>
			<slash:comments>70</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">1732</post-id>	</item>
	</channel>
</rss>
