Compartilhar via


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

Criar o projeto do Node.js

  1. 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.

  2. 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.

  3. 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

  1. 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.

  2. 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.

  3. 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.

  4. 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.

  5. 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;
        }
    

Próxima etapa