Igara - Nota Fiscal Eletrônica
quinta-feira, 2 de setembro de 2010
Busca  
Porta 80 Web Hosting
 :: Acessibilidade
Ir para conteúdo principal: ALT + 1
 :: Participe
Seja um autor de CD/DVD de Treinamento
Publique um artigo
Publique uma oportunidade
Publique uma notícia
Publique um curso
Publique uma dica
Publique um código
 :: Informativo
Receba nossos informativos por e-mail.
E-mail:   
 
Digite a palavra abaixo:  
 
 
 :: Oportunidades
Cadastrar oportunidades
Gerenciar suas oportunidades
Cadastrar nova empresa
 :: Especiais
Básico de C++
C++ Builder
Curso ASP.NET 3.5 em VB.NET e C#
Guia Prático de HTML
Testes com Visual Studio Team System 2008
 :: Desenvolvimento
ActionScript
ADO.NET
ASP
ASP.NET
Automação Comercial
C#
C/C++
Coldfusion
CSS
Delphi
Disp. Móveis
HTML
Java
Javascript
LSL (Second Life)
Modelagem
PHP
Python
Sharepoint
Silverlight
SQL
VBA (Office)
Visual Basic
Visual Basic .NET
Visual Fox Pro
WCF/WPF
Web Services
XML
 :: Infra
BizTalk Server
CRM
Exchange Server
ForeFront / Antigen / IAG
Interoperabilidade
ISA Server
Linux
MOF
MS Dynamics CRM
Network
OCS / LCS
Outlook
Powershell e Scripts
Redes
Segurança
System Center e Gerenciamento
Virtualização
Windows
Windows Server
 :: Banco de Dados
Access
Caché
Firebird
Interbase
MySQL
Oracle
SQL Server
Sybase
 :: Gerência
Arquitetura
Ciclo de Vida de Desenvolvimento
Controle de Versão
Estimativas
Metodologias
MOF
Qualidade e Testes
 :: Design
Corel
Flash
Photopaint
Photoshop
 :: Livros
Análise Sistemas
Aplicativos
Banco de Dados
Certificação
Design e CAD
Gerência
Hardware
Internet
Programação
Programação Web
Rede
Segurança
Servidores
Sistemas Operacionais
 :: CDs/DVDs
Desenvolvimento
Infra
Design
 :: E-Books
.NET 2.0 (VS 2005)
.NET 1.1 (VS 2003)
SQL Server
Excel 2007
Excel 2003
Access 2003
ASP 3.0
Delphi
Java
Artigos
Encriptando valores passados por QueryString
Por: Rodolfo Paoni
[Entre em contato com o autor ]
Bacharel em Sistemas de Informação e desenvolvedor .NET em uma Gold Partner da Microsoft em Petrópolis, R.J.. Sou certificado Microsoft MCP (.NET 2.0), MCTS (Windows, Web e Distributed 2.0 e Web 3.5) e MCPD (Web e Windows 2.0). Atuou como aluno embaixador da Microsoft (MSP - Microsoft Student Partner) durante os anos de 2008 e 2009. Atualmente desenvolve sistemas web e ministra treinamentos nesta área.
Site: rodolfopaoni.ctallen.com.br
Feed de artigos.
Feed de artigos deste autor.
Gere seu feed personalizado  
MS TechEd 2010

Encriptando valores passados por QueryString
Publicado em: 03/02/2010

Nem sempre os valores que passamos por QueryString em nossas páginas são controlados da maneira que deveriam. Existem formas de melhorar essa abordagem utilizando encriptação. É interessante utilizar nomes que não definiam claramente o que é passado naquele campo, por exemplo: "p", "p1", "p2", etc. Assim o usuário final não faz noção do que aquele valor representa e com a técnica de encriptação, isso fica ainda menos claro.

Abaixo demonstro uma classe com 2 métodos estáticos para realizar este trabalho:

public static class EncryptParam
{
    public static string Encrypt(string stringToEncrypt)
    {
        try
        {
            Byte[] b = System.Text.ASCIIEncoding.UTF8.GetBytes(stringToEncrypt);
            return Convert.ToBase64String(b);
        }
        catch
        {
            return string.Empty;
        }
    }

    public static string Decrypt(string stringToDecrypt)
    {
        try
        {
            Byte[] b = Convert.FromBase64String(stringToDecrypt);
            return System.Text.ASCIIEncoding.UTF8.GetString(b);
        }
        catch
        {
            return string.Empty;
        }
    }
}

Lembre-se: Os valores não estão critografados, apenas encriptados. Isso significa que ainda sim não existe total segurança, mas ao menos minimiza-se a vulnerabilidade do sistema com relação à QueryStrings.

Como recuperar e validar os parâmetros encriptados?
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!Page.IsPostBack)
        {
        // Validando o parâmetro "p"

            // Parâmetro não informado
        if (string.IsNullOrEmpty(Request.QueryString["p"]))
            {
                ClientScript.RegisterStartupScript(typeof(string), string.Empty,
              "window.alert(\"Parâmetro não informado.\");history.go(-1);", true);
            }
            // Parâmetro Inválido
            else if (EncryptParam.Decrypt(Request.QueryString["p"].Trim()).Equals(string.Empty))
            {
          ClientScript.RegisterStartupScript(typeof(string), string.Empty,
              "window.alert(\"Parâmetro inválido.\");history.go(-1);", true);
            }
            // Parâmetro válido
            else
            {
                // Decriptando o valor da Url
                Response.Write(EncryptParam.Decrypt(Request.QueryString["p"].Trim()));
            }
    }
}

Um abraço e bons códigos!







 

Inclua um comentário sobre o artigo Topo
Elogios e críticas são muito bem vindos, porém o comentário deve ter referência ao artigo em pauta.
O portal e o autor agradecem.
Nome:    
E-mail:      
Comentários:    
Digite a palavra abaixo:  
Para dúvidas técnicas, NÃO UTILIZE ESTE ESPAÇO, utilize nosso fórum de discussão.
http://linhadecodigo.com.br/cs2/forum
 
Comentários sobre o artigo Ver Todos comentários
Olá, Israel
Sim, de fato não é realizada criptografia e sim uma codificação dos valores. Costumo utilizar nomes que não descrevam claramente o que cada valor significa (Ex.: "p", "p1", "p2", etc) e também passar o mínimo de valores possível por QueryString, o que é uma boa prática. Acredito que, em se tratando de segurança, ainda está longe do ideal, mas para 90% dos usuários há uma melhoria com relação à livre alteração dos valores, principalmente com o tratamento que demonstro no exemplo de uso, onde é minimizada essa possibilidade. Para efetiva criptografia, podemos utilizar a mesma idéia que apresentei, porém criptografando os valores com a seguinte classe: http://www.linhadecodigo.com.br/Artigo.aspx?id=2709, onde é utilizada criptografia efetiva dos valores.
Um grande abraço
Quem enviou: Rodolfo Paoni
Postado em: 06/02/2010 00:00:00
Boas Rodolfo,

Esse código não está criptografando as informações. Ele está apenas codificando elas.

Do ponto de vista de segurança, você ainda continua vulnerável. O título correto para o artigo deveria ser: "Codificando valores passados por QueryString".
Quem enviou: Israel Aece
Postado em: 04/02/2010 00:00:00
Artigo baseado na seguinte Thread do MSDN:
http://social.msdn.microsoft.com/forums/en-US/netfxbcl/thread/5650db8d-d96b-4da9-9017-9896351c0047/
Quem enviou: Rodolfo Paoni
Postado em: 03/02/2010 00:00:00
Outros artigos do autor Topo
Compactação de ViewState em ASP.NET - Parte 2 (Colocando na Session)
Truques em coleções com LINQ e C# 3.0 - Parte 1
Tratamento de excessões em aplicações N-Tier
Generics com C# e .NET 2.0
Explorando as Coleções do .NET Framework - Parte 2
Explorando as Coleções do .NET Framework - Parte 1
Explorando alguns Delegates do C# 2.0: Predicates, Converter, Comparison e Action
Delegates e eventos no C# 2.0 - Parte 2
Delegates e eventos no C# 2.0 - Parte 1
Compactação de ViewState em ASP.NET
Gerando JavaScript do lado do servidor com ASP.NET
Compactação com GZipStream e DeflateStream
Introdução ao LINQ - Parte III (LINQ to SQL - Stored Procedures)
Introdução ao LINQ - Parte 2 (LINQ to SQL)
Introdução ao LINQ
Artigos relacionados Topo
Melhorando WinApps seguindo WebApps
Cadastro de um Consultório em Windows Forms, com C# e SQL Server – Parte 12
Criar arquivo de integração com Integration Services
Trabalhando com Array Params no C#
Pegando o horário inicial e final do uso do Windows usando C#
Como funcionam as Arrays (Matrizes) Multidimensionais no C#?
Cadastro de um Consultório em Windows Forms, com C# e SQL Server – Parte 11
Documentação de Código .Net
ASP.NET MVC Custom Helpers
Eval em C# com IronRuby
Trabalhando com CLR: Stored Procedure – Primeiro passo
Entendendo interfaces com C#
Executar aplicações em background com Agendador de Tarefas Windows
ExpandoObject: dinamismo no .NET 4.0
Integração C# + Ruby
Utilizando um Tipo T como parâmetro e recuperando seus valores
Detectando mudanças em objetos
URL Routing com o Visual Studio .NET 2010
Acessando dados com Textboxes e botões de navegação
Controle de Acesso Windows Forms C# - Parte 3
Trabalhando com SQL CLR: Início
Funcionalidades do Office usando Visual Studio for Office – Parte 3
Cadastro de um Consultório em Windows Forms, com C# e SQL Server – Parte 10
Carregar DataGridView utilizando linq to xml
Funcionalidades do Office usando Visual Studio for Office - Parte 2
Estenda as funcionalidades do Office com o Visual Studio for Office
A importância do StrongName
Cadastro de um Consultório em Windows Forms, com C# e SQL Server – Parte 9
Descubra o ADO.NET Entity Framework
Controle de Usuários – Windows Forms C# (Parte 2)
Produtos relacionados Topo
CD/DVD: CD de Treinamento Criando Aplicações Asp.Net em Camadas (parte integrante do portal de vídeos .Net)
Pacote: Promoção: Portal de Vídeos .Net + CD Novidades das Linguagens (válido somente para pagamento via boleto bancário)
CD/DVD: DVD de Treinamento E-Commerce com Visual Web Developer
E-Book: Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
E-Book: ASP.NET Ajax com C# e VB.NET (E-Book com entrega via download)
CD/DVD: CD de Treinamento - Desenvolvendo uma aplicação Smart Client com Visual Studio 2005, C#, Web Services e Banco de Dados
CD/DVD: CD de Treinamento sobre LINQ to SQL para iniciantes com Visual Studio .Net 2008
CD/DVD: CD de Treinamento sobre ADO.NET para Iniciantes
CD/DVD: CD de Treinamento Novidades das Linguagens C# 3.0 e VB 9 (Visual Basic 9)
CD/DVD: CD de Treinamento Introdução a .NET com C# - Visual Studio 2005
CD/DVD: CD ASP.NET 2.0 - Atualização Rápida (Visual Studio .NET 2005)
E-Book: E-Book: Lógica de Programação com C# e VB.NET (via download)
CD/DVD: CD - Treinamento de ASP.NET 2.0 AJAX Extensions
Livro: ASP.NET Utilizando C# - De Programador para Programador
E-Book: E-Book: Programando com C# e Visual Studio .NET 2005 (entrega via download)
E-Book: E-Book: Curso Prático de Visual Studio .NET 2005 (entrega via download)
E-Book: E-Book: Curso prático de Visual Studio .NET (via download)
Livro: Programando em C#.Net para Web: Guia Rápido Usando Visual Studio.Net 2003
CD: CD de Treinamento de Group Policy no Windows Server 2003
© Copyright 2001-2010 Codeline Editora, Comércio e Tecnologia Ltda. | Política de privacidade e de uso | Anuncie | Fale conosco

» Site hospedado na Porta 80 Web Hosting «
Nossos números
Dicas: 1.314
Códigos/scripts: 279
Funções de VBScript : 90
Funções JScript : 05
Livros: 1.805
Notícias: 2.623
Artigos: 3.020
Cases: 14
Oportunidades: 4.591
Vídeos .Net: 484
Publicidade

Conheça a loja do Linha de Código.

Microsoft indica Linha de Código.

Assine a Revista Mundo .NET
Portal de Vídeos .NET - os melhores vídeos .NET estão aqui
O que você fará com o Visual Studio 2010?
Revista Codificando .Net

Siga-nos no Twitter

Linha de Código no Orkut
Fórum de discussão do portal Linha de Código
Feeds
Oportunidades
Notícias
Artigos
Artigos personalizado
       (Por assunto)
Artigos personalizado
       (Por autor)
Portal Vídeos .NET
Portal Vídeos Delphi
LC Blog
       (Onde você faz a notícia)
Promoções
Promoção Wordpress + Tabless (válido somente para pagamento via boleto bancário)
Promoção Wordpress + Tabless (válido somente para pagamento via boleto bancário)
De: R$ 149,70
Por: R$ 99,80
Promoção PHP + MYSQL Intelimax (válido somente para pagamento via boleto bancário)
De: R$ 308,00
Por: R$ 219,00
Promoção Especial Infra
De: R$ 175,95
Por: R$ 136,00
Promoção: Portal de Vídeos .Net + CD Novidades das Linguagens (válido somente para pagamento via boleto bancário)
De: R$ 162,00
Por: R$ 89,00
Promoção VSTS (válido somente para pagamento via boleto bancário)
De: R$ 219,00
Por: R$ 146,00
CDs/DVDss
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
Por: R$ 59,00
DVD Curso de CorelDraw X4
Por: R$ 79,90
DVD Curso de Fireworks CS4
Por: R$ 49,90
DVD Curso de Indesign CS4
Por: R$ 55,00
DVD Curso de Efeitos Digitais
Por: R$ 49,90
Livros
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
De: R$ 129,00
Por: R$ 77,40
Foundation FLASH CS3 para Designers
Ciência Moderna
De: R$ 139,00
Por: R$ 83,40
ALGORITMOS O Guia Essencial
Alta Books
De: R$ 64,90
Por: R$ 58,40
Treinamento Prático em Dreamweaver
Digerati Books
Por: R$ 14,95
Estudo Dirigido de Adobe Photoshop CS4 em português - Para Windows
Erica
De: R$ 88,00
Por: R$ 74,80
E-Books
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Por: R$ 30,00
Manual de Estudos - Exame 70-291 - Windows Server 2003 (606 páginas) - entrega via download
Por: R$ 30,00
Dominando MS – Visio ® em 20 Passos - Melhores Práticas em Gestão de Projetos (entrega via download)
Por: R$ 30,00
MS-Project® 2007 - Melhores Práticas de Gestão de Projetos - Dominando MS – Project ® em 20 Passos (e-book com entrega via download)
Por: R$ 20,00
Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
Por: R$ 20,00
Os 10+ | Autores do dia
Israel Aéce
Júlio Cesar Fabris Battisti
Anderson Patricio
Luiz Felipe de Freitas
Marcio Franco
Eric C M Oliveira
Robert Martim
Ramon Durães
Alessandro de Oliveira Faria
Alfred Reinold Baudisch
Os 10+ | Artigos do dia
HTML Básico
HTML Avançado
Criando aplicativos para o Orkut
PL/SQL - Procedures e Funções
Tutorial de Tabelas Dinâmicas no Excel – Parte 1
Como configurar Conexão Remota no SQL Server 2005
WCF – Gerenciamento de Instância
Básico de C++: Estrutura de um programa em C++
ASP.NET 2.0 - Explorando o GridView
Tutorial: Desenhando com o Corel Draw