VAGAS DE EMPREGO

balta.io balta.io
  • Cursos
  • Carreiras
  • Para sua Empresa
  • Livros
    • Background Services
    • Blazor com .NET 8
    • Segurança em APIs
    • Futuro do C# 12
    • Nullable Types
    • Clean Code
  • Blog

Seja Premium
balta.io

  • Cursos
  • Carreiras
  • Para sua Empresa
  • Agenda
  • Livros
    • Background Services
    • Blazor com .NET 8
    • Segurança em APIs
    • Futuro do C# 12
    • Nullable Types
    • Clean Code
  • Blog
  • Player
Seja Premium

Entre ou Cadastre-se

  • Home
  • Artigos
  • Gerando QRCode no ASP.NET Razor Pages


👉 Temos uma versão mais atualizada deste artigo no nosso novo Blog

Gerando QRCode no ASP.NET Razor Pages

Neste artigo vamos aprender a gerar um QRCode usando o template Razor Pages em ASP.NET Core de forma simples e rápida.

Criando a aplicação

Este projeto mostra como trabalhar com geração e renderização de um QRCode em um projeto Razor Pages no ASP.NET Core.

dotnet new razor -o render-qrcode
cd render-qrcode

Instalando os pacotes via NuGet

Para facilitar nosso trabalho, vamos utilizar dois pacotes: QRCoder e System.Drawing.Common

dotnet add package QRCoder -v 1.4.2
dotnet add package System.Drawing.Common

Pronto! Temos nosso projeto criado com os pacotes necessários para começarmos.

Organizando o projeto

A ideia aqui é criar uma classe estática chamada QrCodeServices dentro de um arquivo chamado Services.cs, que vai permitir o reúso do QRCode em diferentes pontos da nossa aplicação.

public static class QrCodeServices
{
}

Gerando o QRCode

O trecho para gerar um QRCode utilizando o QRCoder é bem simples, precisamos do QRCodeGenerator e dos dados do QRCode.

public static Bitmap GenerateImage(string content)
{
    var qrGenerator = new QRCodeGenerator();
    var qrCodeData = qrGenerator.CreateQrCode(content, QRCodeGenerator.ECCLevel.Q);
    var qrCode = new QRCode(qrCodeData);
    var qrCodeImage = qrCode.GetGraphic(20);

    return qrCodeImage;
}

Agora vamos escrever um método para injetar nosso bitmap em uma tag html <img>. Para isso, vamos converter o objeto do tipo System.Drawing.Bitmap em uma imagem que pode ser usada em uma tag html <img>, primeiro precisamos salvar o bitmap em um fluxo de memória e, em seguida, converter o fluxo em uma sequência de bytes. Por fim, é possível criar uma string com a sintaxe correta para uma tag html <img> e definir o valor do atributo src como um data URI contendo a sequência de bytes da imagem.

public static string BitmapToImageSource(string content)
{
    var bitmap = GenerateImage(content);
    var imageSource = string.Empty;
    
    using (MemoryStream memoryStream = new MemoryStream())
    {
        bitmap.Save(memoryStream, System.Drawing.Imaging.ImageFormat.Png);

        byte[] imageBytes = memoryStream.ToArray();

        imageSource = $"data:image/png;base64,{Convert.ToBase64String(imageBytes)}";
    }

    return imageSource;
}

Como resultado final, nossa classe ficou com os seguintes métodos.

using QRCoder;
using System.Drawing;

public static class QrCodeServices
{
    public static Bitmap GenerateImage(string content)
    {
        var qrGenerator = new QRCodeGenerator();
        var qrCodeData = qrGenerator.CreateQrCode(content, QRCodeGenerator.ECCLevel.Q);
        var qrCode = new QRCode(qrCodeData);
        var qrCodeImage = qrCode.GetGraphic(20);

        return qrCodeImage;
    }

    public static string BitmapToImageSource(string content)
    {
        var bitmap = GenerateImage(content);
        var imageSource = string.Empty;
        
        using (MemoryStream memoryStream = new MemoryStream())
        {
            bitmap.Save(memoryStream, System.Drawing.Imaging.ImageFormat.Png);

            byte[] imageBytes = memoryStream.ToArray();

            imageSource = $"data:image/png;base64,{Convert.ToBase64String(imageBytes)}";
        }

        return imageSource;
    }
}

Utilizando o QRCode

Agora vamos trabalhar na interface para obtenção dos dados que darão origem ao QRCode. Vamos criar uma página com o nome GenerateQrCode, vamos adicionar um formulário que será submetido com o método post, contendo um <input> e um <button>.

<form method="post">
  <div class="form-floating mb-3">
    <input asp-for="ContentQrCode" class="form-control" id="floatingInput" placeholder="Conteúdo QR Code">
    <span asp-validation-for="ContentQrCode" class="text-danger"></span>
    <label for="floatingInput">Conteúdo QR Code</label>
  </div>
  
  <div class="col-12">
      <button asp-page="RenderQrCode" class="btn btn-primary" type="submit">Gerar QR Code</button>
  </div>
</form>

Vamos fazer também a chamado do jQuery para validar nosso formulário do lado do cliente.

@section scripts{
   <partial name="_ValidationScriptsPartial" />
}

Nossa página ficará com o seguinte conteúdo:

@page
@model GenerateQrCodeModel
@{
    ViewData["Title"] = "Gerar QRCode";
}
<h1>@ViewData["Title"]</h1>

<form method="post">
  <div class="form-floating mb-3">
    <input asp-for="ContentQrCode" class="form-control" id="floatingInput" placeholder="Conteúdo QR Code">
    <span asp-validation-for="ContentQrCode" class="text-danger"></span>
    <label for="floatingInput">Conteúdo QR Code</label>
  </div>
  
  <div class="col-12">
      <button asp-page="RenderQrCode" class="btn btn-primary" type="submit">Gerar QR Code</button>
  </div>
</form>

@section scripts{
   <partial name="_ValidationScriptsPartial" />
}

Em Razor Pages, todas as páginas com extensão .cshtml vem acompanhada de um arquivo .cshtml.cs de mesmo nome, onde escrevemos nossos códigos em C#, que serão processados do lado servidor.

Nesse arquivo, vamos criar uma propriedade do tipo string que estará ligada ao nosso input, segue como ficou nosso arquivo .cshtml.cs:

using Microsoft.AspNetCore.Mvc.RazorPages;
using System.ComponentModel.DataAnnotations;

namespace render_qrcode.Pages;

public class GenerateQrCodeModel : PageModel
{
    private readonly ILogger<GenerateQrCodeModel> _logger;

    public GenerateQrCodeModel(ILogger<GenerateQrCodeModel> logger)
    {
        _logger = logger;
    }

    [Required(ErrorMessage="Favor informar o conteúdo do QR Code!")]
    public string ContentQrCode { get; set; } = null!;

    public void OnGet()
    {
    }
} 

Agora vamos trabalhar na interface que irá propriamente gerar e renderizar nosso QRCode, vamos adicionar uma nova página com o nome RenderQrCode, contendo um <img> onde iremos renderizar o QRCode, e um <button> onde daremos a opção ao usuário de voltar a página anterior, da seguinte forma:

@page "~/renderqrcode/{content?}"
@model RenderQrCodeModel
@{
    ViewData["Title"] = "Renderização QRCode";
}
<h1>@ViewData["Title"]</h1>

<div class="text-center">
  <img src=@Model.imageSource class="rounded" alt="QRCode" width="400" height="400">
</div>

<div class="col-12">
    <a asp-page="GenerateQrCode"><button class="btn btn-primary">Voltar</button></a>
</div>

Vamos agora trabalhar no arquivo .cshtml.cs da nossa página, precisamos incluir uma propriedade que irá armazenar o source da imagem que iremos injetar na tag <img>, e capturar o conteúdo do QRCode que nos foi enviado por post. Teremos o seguinte resultado:

using Microsoft.AspNetCore.Mvc.RazorPages;

namespace render_qrcode.Pages;

public class RenderQrCodeModel : PageModel
{
    private readonly ILogger<RenderQrCodeModel> _logger;

    public RenderQrCodeModel(ILogger<RenderQrCodeModel> logger)
    {
        _logger = logger;
    }

    public string imageSource = "";

    public void OnPost(string content)
    {
        imageSource = QrCodeServices.BitmapToImageSource(Request.Form["ContentQrCode"]);
    }
}

Para finalizarmos, vamos fazer a chamada da página GenerateQrCode no leiaute do nosso template.

<li class="nav-item">
    <a class="nav-link text-dark" asp-area="" asp-page="/GenerateQrCode">Gerar QRCode</a>
</li>

Pronto! Temos um gerador de QRCode em Razor Pages ASP.NET Core.

render-qrcode-1 render-qrcode-2 render-qrcode-3

Código fonte:

https://github.com/jfs-dev/render-qrcode-web/

Referências

https://learn.microsoft.com/pt-br/aspnet/core/razor-pages/?view=aspnetcore-7.0&tabs=visual-studio/

https://github.com/codebude/QRCoder/

https://balta.io/blog/aspnet-qrcode/

Populares

Priority Queue

Priority Queue ou fila prioritária é um tipo de lista inclusa no C# 10 que permite que seus itens...


Implicit Operators no C#

Implicit Operators permitem adicionar comportamentos de conversão a objetos Built In ou complexos...


ASP.NET 5 – Autenticação e Autorização com Bearer e JWT

Este artigo atualmente utiliza a versão 5.0.0-rc.1 do ASP.NET/.NET, o que significa que ainda não...


Clean Code - Guia e Exemplos

Saiba como manter seu código limpo (Clean Code) seguindo algumas práticas sugeridas pelo Robert C...


Git e GitHub - Instalação, Configuração e Primeiros Passos

Git é um sistema de controle de versões distribuídas, enquanto GitHub é uma plataforma que tem o ...


Compartilhe este artigo



Conheça o autor

Jeú Franco da Silva

Jeú Franco da Silva

Gerente de Sistemas na GMAF

Jeú trabalha com desenvolvimento de softwares há mais de 23 anos, aprendendo constantemente, compartilhando conhecimentos e aplicando na prática os conhecimentos adquiridos através de uma boa escrita de código.





3.133

Aulas disponíveis

292

horas de conteúdo

76.461

Alunos matriculados

53.012

Certificados emitidos





Comece de graça agora mesmo!

Temos mais de 21 cursos totalmente de graça e todos com certificado de conclusão.

Começar


Prefere algo mais Premium?

Conheça nossos planos



Premium anual

Compra única, parcelada em até
12x no cartão de crédito


12x R$

99

,79

=R$ 1.197,44
  • 1 ano de acesso
  • Acesso à todo conteúdo
  • Emissão de Certificado
  • Tira Dúvidas Online
  • 67 cursos disponíveis
  • 10 carreiras disponíveis
  • 161 temas de tecnologia
  • Conteúdo novo todo mês
  • Encontros Premium

Começar agora

Política de privacidade



Precisa de ajuda?

Dúvidas frequentes



  • Posso começar de graça?

    Sim! Basta criar sua conta gratuita no balta.io e começar seus estudos. Nós contamos com diversos cursos TOTALMENTE gratuitos e com certificado de conclusão.

  • Vou ter que pagar algo?

    Nós temos cursos gratuitos e pagos, porém você não precisa informar nenhum dado de pagamento para começar seus estudos gratuitamente conosco. Os cursos gratuitos são completos e com certificado de conclusão, você não paga nada por eles.

    Porém, caso queira algo mais Premium , você terá acesso à diversos benefícios que vão te ajudar ainda mais em sua carreira.

  • Por onde devo começar?

    Siga SEMPRE as nossas Carreiras , elas vão te orientar em todos os sentidos. Os cursos já estão organizados em categorias e carreiras para facilitar seu aprendizado.
    Nossa sugestão para aprendizado é começar pelo Backend e seguindo para Frontend e Mobile.

    • Backend
    • Frontend
    • Mobile

  • Os cursos ensinam tudo que preciso?

    Nenhum curso no mundo vai te ensinar tudo, desculpa ser sincero! Os cursos são uma base, eles fornecem por volta de 30% do que você precisa aprender, o resto é com você, com dedicação e MUITA prática.

  • O que eu devo estudar?

    Java ou .NET? Angular ou React? Xamarin ou Flutter? A resposta é simples e direta: "Você já sabe o básico?"

    Se você ainda não sabe BEM o básico, ou seja, os fundamentos, OOP, SOLID, Clean Code, está perdendo tempo estudando Frameworks ou até coisas mais avançadas como Docker. Foque nos seus objetivos primeiro.
    Agora se você está indeciso sobre qual Framework estudar, a boa notícia é que o mercado neste momento está bem aquecido e você tem várias oportunidade. Desta forma o que levaríamos em conta para tomar esta decisão seria:

    • Já sei o básico
    • O Framework/Tecnologia tem mercado onde eu estou (região)
    • O Framework/Tecnologia é utilizado em uma empresa onde quero atual
    • O Framework/Tecnologia resolve meu problema
    • Eu gosto de utilizar o Framework/Tecnologia

  • Estou pronto para estudar no balta.io?

    Com certeza! O primeiro passo é começar e você pode fazer isto agora mesmo!

    Começar de graça

Ainda tem dúvidas?





Assine nosso Newsletter

Receba em primeira mão todas as nossas novidades.

Cadastrar


balta.io

Sobre

  • Como funciona?
  • Seja Premium
  • Agenda
  • Blog
  • Todos os cursos

Cursos

  • Frontend
  • Backend
  • Mobile
  • Fullstack

Suporte

  • Termos de uso
  • Privacidade
  • Cancelamento
  • Central de ajuda

Redes Sociais

  • Telegram
  • Facebook
  • Instagram
  • YouTube
  • Twitch
  • LinkedIn
  • Discord