Novo Projeto - dúvida na tecnologia a ser utilizada

Gilcecler Carneiro 25 Pontos de reputação
2024-09-12T17:21:24.13+00:00

Um novo projeto blazor wasm e blazer server app . Minha dúvida é que no server dois models ou dois entities precisam ser atualizados por um programa de terceiros, externo a minha aplicação, que consumiria minha api.

o server já expoe a API que o blazer client vai consumir é conveniente consumir esta mesma API com este programa externo ?

É possível criar um Jwt para o blazor cliente e outro para o consumo do programa externo ?

Esta aplicação tem que ser multi-tenant também.

Estou na dúvida qual seria a melhor stack de tecnologias.

ASP.NET
ASP.NET
Um conjunto de tecnologias no .NET Framework para criar aplicativos Web e serviços Web XML.
9 perguntas
0 comentários Sem comentários
{count} votos

Resposta aceita
  1. Jonathan Pereira Castillo 11,220 Pontos de reputação Fornecedor da Microsoft
    2024-09-12T18:08:00.9033333+00:00

    Oi Gilcecler Carneiro!

    Bem-vindo ao Microsoft Q&A!

    Vamos por partes para abordar suas dúvidas:

    Blazor WASM vs Blazor Server

    Blazor WebAssembly (WASM) executa a aplicação no navegador, proporcionando uma experiência mais rápida e offline, mas pode ter um tempo de carregamento inicial maiorBlazor Server, por outro lado, executa a aplicação no servidor e envia atualizações para o cliente via SignalR, resultando em um tempo de carregamento inicial mais rápido e menor uso de recursos no cliente.

    Consumo da API por Programa Externo

    Sim, é conveniente e eficiente que o program/en-us/aspnet/core/blazor/hosting-moda externo consuma a mesma API que o Blazor Client. Isso promove a reutilização de código e facilita a manutenção.

    JWT para Blazor Cliente e Programa Externo

    É possível criar JWTs separados para o Blazor Client e para o programa externo. Você pode configurar diferentes políticas de autenticação e autorização no ASP.NET Core para gerenciar isso. Aqui está um exemplo básico de como configurar JWTs:

    1. Configuração do JWT no Startup.cs: C#
         public void ConfigureServices(IServiceCollection services)
         {
             services.AddAuthentication(options =>
             {
                 options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
                 options.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
             })
             .AddJwtBearer(options =>
             {
                 options.TokenValidationParameters = new TokenValidationParameters
                 {
                     ValidateIssuer = true,
                     ValidateAudience = true,
                     ValidateLifetime = true,
                     ValidateIssuerSigningKey = true,
                     ValidIssuer = Configuration["Jwt:Issuer"],
                     ValidAudience = Configuration["Jwt:Audience"],
                     IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(Configuration["Jwt:Key"]))
                 };
             });
             services.AddAuthorization(options =>
             {
                 options.AddPolicy("BlazorClientPolicy", policy => policy.RequireClaim("Client", "Blazor"));
                 options.AddPolicy("ExternalProgramPolicy", policy => policy.RequireClaim("Client", "ExternalProgram"));
             });
             services.AddControllers();
         }
         
      
    2. Gerar Tokens Diferentes:
         public string GenerateToken(string clientType)
         {
             var claims = new[]
             {
                 new Claim(JwtRegisteredClaimNames.Sub, "user"),
                 new Claim("Client", clientType)
             };
             var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(Configuration["Jwt:Key"]));
             var creds = new SigningCredentials(key, SecurityAlgorithms.HmacSha256);
             var token = new JwtSecurityToken(
                 issuer: Configuration["Jwt:Issuer"],
                 audience: Configuration["Jwt:Audience"],
                 claims: claims,
                 expires: DateTime.Now.AddMinutes(30),
                 signingCredentials: creds);
             return new JwtSecurityTokenHandler().WriteToken(token);
         }
         
      

    Multi-Tenant

    Para uma aplicação multi-tenant, você pode usar o Entity Framework Core junto com ASP.NET Core. Isso permite que você isole os dados de cada tenant enquanto compartilha a mesma infraestrutura.

    Melhor Stack de Tecnologias

    Considerando suas necessidades:

    • Blazor WebAssembly para uma experiência de usuário mais rica e offline.
    • ASP.NET Core para o backend, expondo APIs que podem ser consumidas tanto pelo Blazor Client quanto pelo programa externo.
    • Entity Framework Core para gerenciar dados multi-tenant.

    Espero que essas dicas ajudem a resolver o problema! Se precisar de mais assistência, estou à disposição.

    Saudações

    Jonathan.

    -----------

    Se você acha que as informações fornecidas acima resolveram sua dúvida, agradeceríamos se você pudesse marcá-la como "Aceite a resposta se achar útil". Isso nos ajuda a manter a qualidade e a relevância das soluções em nosso fórum.

    1 pessoa achou esta resposta útil.
    0 comentários Sem comentários

5 respostas adicionais

Classificar por: Mais útil
  1. Jonathan Pereira Castillo 11,220 Pontos de reputação Fornecedor da Microsoft
    2024-10-25T21:22:30.7433333+00:00

    Agradeço sinceramente pela oportunidade de ajudar. É gratificante saber que as informações fornecidas foram úteis.

    Espero ter a chance de auxiliar novamente no futuro, com qualquer outra dúvida que possa surgir.

    Atenciosamente,

    Jonathan

    0 comentários Sem comentários

Sua resposta

As respostas podem ser marcadas como Respostas Aceitas pelo autor da pergunta, o que ajuda os usuários a saber a resposta que resolveu o problema do autor.