<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Jwt on Car Store</title><link>https://professor-enoqueleal.github.io/tags/jwt/</link><description>Recent content in Jwt on Car Store</description><generator>Hugo</generator><language>pt</language><lastBuildDate>Fri, 08 May 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://professor-enoqueleal.github.io/tags/jwt/index.xml" rel="self" type="application/rss+xml"/><item><title>LAB 9 - Protegendo a Camada API (REST) com Spring Security e JWT</title><link>https://professor-enoqueleal.github.io/posts/laboratorio-9-tsw/</link><pubDate>Fri, 08 May 2026 00:00:00 +0000</pubDate><guid>https://professor-enoqueleal.github.io/posts/laboratorio-9-tsw/</guid><description>&lt;h2 id="-objetivo">🔒 Objetivo&lt;/h2>
&lt;p>Neste laboratório, iremos configurar o Spring Security para proteger a camada de API da aplicação &lt;code>carstore-spring-boot&lt;/code>. Ao contrário da camada web (LAB 8), a API será &lt;strong>stateless&lt;/strong> (sem sessão) e usará o protocolo de autenticação &lt;strong>JWT (JSON Web Tokens)&lt;/strong>.&lt;/p>
&lt;p>Ao final deste laboratório, você deverá saber:&lt;/p>
&lt;ul>
&lt;li>Configurar o Spring Security para um fluxo &lt;strong>stateless&lt;/strong> (sem sessão).&lt;/li>
&lt;li>Criar um &lt;strong>Endpoint de Autenticação&lt;/strong> (&lt;code>/api/auth/login&lt;/code>) que retorna um JWT.&lt;/li>
&lt;li>Implementar um &lt;strong>Filtro de Autorização JWT&lt;/strong> para validar tokens em todas as requisições da API.&lt;/li>
&lt;li>Proteger rotas específicas da API (ex: &lt;code>/api/admin/**&lt;/code>).&lt;/li>
&lt;li>Testar a autenticação de API usando ferramentas como Postman.&lt;/li>
&lt;/ul>
&lt;h2 id="pré-requisitos">Pré-requisitos&lt;/h2>
&lt;ul>
&lt;li>Ter completado os laboratórios anteriores (LAB 7 e LAB 8).&lt;/li>
&lt;li>Projeto &lt;code>carstore-spring-boot&lt;/code> compilando localmente.&lt;/li>
&lt;li>Ferramenta para testar APIs (Postman).&lt;/li>
&lt;/ul>
&lt;hr>
&lt;h2 id="parte-a-configurando-a-camada-de-api-stateless">Parte A: Configurando a Camada de API (Stateless)&lt;/h2>
&lt;h3 id="tarefa-1-dependências-adicionais">Tarefa 1: Dependências Adicionais&lt;/h3>
&lt;p>Adicione a dependência do JWT no &lt;code>pom.xml&lt;/code> da aplicação:&lt;/p></description></item></channel></rss>