Tutorial: Criar um aplicativo Web Node.js para conectar usuários
Este tutorial é a parte 2 de uma série que demonstra a criação de um aplicativo Web Node.js e sua preparação para autenticação usando o centro de administração do Microsoft Entra. Na parte 1 desta série, você registrou um aplicativo e configurou fluxos de usuários em seu locatário externo. Neste tutorial, você cria um projeto Node.js(Express) e organiza todas as pastas e arquivos necessários. Habilite a entrada no aplicativo que você preparou aqui. As exibições do aplicativo Web Node.js (Express) usam handlebars.
Neste tutorial você irá;
- Criar um projeto Node.js
- Instalar dependências
- Adicionar exibições de aplicativos e componentes da interface do usuário
Pré-requisitos
- Tutorial: Preparar seu locatário externo para conectar usuários em um aplicativo Web Node.js
- Embora qualquer ambiente de desenvolvimento integrado (IDE) compatível com aplicativos do React possa ser utilizado, esse tutorial usa o Visual Studio Code.
- Node.js.
- Visual Studio Code ou outro editor de código.
Criar o projeto do Node.js
Em um local de sua escolha no seu computador, crie uma pasta para hospedar seu aplicativo de nó, como ciam-sign-in-node-express-web-app.
No seu terminal, altere o diretório na sua pasta do aplicativo Web Node, como
cd ciam-sign-in-node-express-web-app
, e execute o seguinte comando para criar um novo projeto Node.js:npm init -y
O comando
init -y
cria um arquivo package.json padrão para seu projeto Node.js.Crie pastas e arquivos adicionais para obter a seguinte estrutura de projeto:
ciam-sign-in-node-express-web-app/ ├── server.js └── app.js └── authConfig.js └── package.json └── .env └── auth/ └── AuthProvider.js └── controller/ └── authController.js └── routes/ └── auth.js └── index.js └── users.js └── views/ └── layouts.hbs └── error.hbs └── id.hbs └── index.hbs └── public/stylesheets/ └── style.css
Instalar dependências do aplicativo
Para instalar os pacotes npm relacionados à identidade e ao Node.js necessários, execute o seguinte comando no seu terminal
npm install express dotenv hbs express-session axios cookie-parser http-errors morgan @azure/msal-node
Criar componentes de interface do usuário do aplicativo
No editor de código, abra o arquivo views/index.hbs e adicione o seguinte código:
<h1>{{title}}</h1> {{#if isAuthenticated }} <p>Hi {{username}}!</p> <a href="/users/id">View ID token claims</a> <br> <a href="/auth/signout">Sign out</a> {{else}} <p>Welcome to {{title}}</p> <a href="/auth/signin">Sign in</a> {{/if}}
Nessa exibição, se o usuário estiver autenticado, mostraremos o respectivo nome de usuário e links para visitar os pontos de extremidade
/auth/signout
e/users/id
, caso contrário, o usuário precisará visitar o ponto de extremidade/auth/signin
para entrar. Definiremos as rotas expressas para esses pontos de extremidade mais adiante neste artigo.No editor de código, abra o arquivo views/id.hbs e adicione o seguinte código:
<h1>Azure AD for customers</h1> <h3>ID Token</h3> <table> <tbody> {{#each idTokenClaims}} <tr> <td>{{@key}}</td> <td>{{this}}</td> </tr> {{/each}} </tbody> </table> <a href="/">Go back</a>
Usaremos essa exibição para exibir declarações de token de ID que a ID externa do Microsoft Entra retorna a esse aplicativo depois que um usuário entra com êxito.
No editor de código, abra o arquivo views/error.hbs e adicione o seguinte código:
<h1>{{message}}</h1> <h2>{{error.status}}</h2> <pre>{{error.stack}}</pre>
Usaremos essa exibição para exibir os erros que ocorrerem quando o aplicativo for executado.
No editor de código, abra o arquivo views/layout.hbs e adicione o seguinte código:
<!DOCTYPE html> <html> <head> <title>{{title}}</title> <link rel='stylesheet' href='/stylesheets/style.css' /> </head> <body> {{{content}}} </body> </html>
O arquivo
layout.hbs
está no arquivo de layout. Ele contém o código HTML que necessitamos em toda a exibição do aplicativo.No editor de código, abra o arquivo public/stylesheets/style.css e adicione o seguinte código:
body { padding: 50px; font: 14px "Lucida Grande", Helvetica, Arial, sans-serif; } a { color: #00B7FF; }