Upload
marcin
View
40
Download
0
Tags:
Embed Size (px)
DESCRIPTION
Segurança na Web Java, ActiveX, JavaScript. por Hednilson Bezerra Hugo Morais Vicente Beltrão. Programação. Conteúdos Executáveis Segurança em Java Segurança em ActiveX Java vs. ActiveX Segurança em JavaScript. Programação. Conteúdo Executável Segurança em Java Segurança em ActiveX - PowerPoint PPT Presentation
Citation preview
Segurança na WebJava, ActiveX, JavaScript
por
Hednilson Bezerra
Hugo Morais
Vicente Beltrão
Programação
Conteúdos Executáveis Segurança em Java Segurança em ActiveX Java vs. ActiveX Segurança em JavaScript
Programação
Conteúdo Executável Segurança em Java Segurança em ActiveX Java vs. ActiveX Segurança em JavaScript
Conteúdos Executáveis
programas transportados na rede para rodar em máquinas remotas
idéia muito interessante e poderosa convite a problemas de segurança acesso a certos recursos da máquina
hospedeira programa pode não ser confiável
Conteúdos Executáveis
pode tornar à tona um programa malicioso com a mesma habilidade de destruir tal como hacker
solução não é tão simples como restringir completamente o acesso a recursos dos programas que são baixados
recursos da máquina precisam ser controlados
Conteúdos Executáveis
identificar os recursos e providenciar certos tipos de acesso limitado a estes recursos, de acordo com os ataques que esses recursos podem sofrer
recursos: sistema de arquivos, rede, memória, dispositivos de entrada e saída, controle de processos, ambiente, chamadas ao sistema operacional
Conteúdos Executáveis
Os principais tipos de ataque, causados por conteúdos executáveis são:– ataques de integridade– ataques de disponibilidade– ataques de revelação– ataques de aborrecimento
Segurança em Java
característica de Java: portabilidade applets podem ser dinamicamente carregados
através da rede e serem executados localmente
Web browser + interpretador Java + biblioteca dinâmica
3 níveis de segurança devem ser estudados: a linguagem, as bibliotecas e o web browser
Segurança em JavaA Linguagem
características de segurança da linguagem:– controle de acesso para variáveis e métodos dos
objetos– segurança do sistema de tipos– não uso de ponteiros com tipo de dados da
linguagem– garbage collection– pacotes com espaço de nomes distintos
Segurança em JavaAs Bibliotecas
oferece acesso aos recursos do sistema implementação correta dessas bibliotecas As restrições de acessos dessas bibliotecas:
– mecanismo da linguagem de oferecer restrições de acesso aos métodos e variáveis dos objetos
– ClassLoaders especializados em carregar código importado
– chamadas explícitas ao SecurityManager global para checar a validade de certas operações
Segurança em JavaWeb Browsers
define e implementa a política de segurança para rodar o código Java baixado
SecurityManager controla o acesso aos recursos críticos do sistema
Se o web browser não instala um SecurityManager, um applet poderá ter o mesmo tipo de acesso de uma aplicação Java local
Problemas de Segurança em Java
O SecurityManager não tem um método para controlar a criação de janelas ou controlar o que pode ser mostrado ou tocado
Não há um mecanismo para controlar o acesso do applet aos dispositivos de entrada
Um applet pode alocar uma quantidade de memória arbitrária, criando novos objetos
Segurança em JavaPoder X Segurança
Java foi proposta para providenciar maior poder e flexibilidade às aplicações
balanceamento entre o poder das aplicações e os riscos de segurança do sistema
Qualquer um que esteja considerando usar Java precisa entender que há um aumento nos riscos de segurança, mas ela prover um mecanismo de segurança de certa forma razoável para aplicações da Internet
ActiveX - Introdução
O que é esta nova Tecnologia– Apresentada pela Microsoft na Internet Professional
Developer’s Conference (PDC)– Constitui um conjunto de tecnologias– Formada por ActiveX Control’s, ActiveX Scripting e
ActiveX Documents– Pode ser encarado como uma reformulação da antiga
Tecnologia OLE para a Web– Promove a iteração entre Software em ambiente de rede
ActiveX - Vantagens
Excelente funcionalidade Ambientes amigáveis e iterativos Maior aproximação com o usuário final É baixado uma única vez, a menos da versão
estar desatualizada Bom desempenho por entender diretamente a
linguagem da plataforma Windows 95 e NT
ActiveX - Desvantagens
“Nem tudo são flores...” Ganha-se por um lado e perde por outro A Microsoft apostou na funcionalidade E a segurança ? Esta merece maior atenção
e dedicação A compatibilidade também é um fator
desfavorável (por enquanto)
ActiveX - Segurança
Até que ponto a Web é segura, mesmo antes desta nova tecnologia ?
A maior funcionalidade do ActiveX promove boas ambições aos Hackers
Pode-se Instalar vírus, excluir arquivos Pode acabar com sua máquina e suas
informações Uma vez instalado, ele tem total poder
ActiveX - Segurança
Quais os recursos de proteção ? O Internet Explorer (acima da versão 3.0),
oferece três níveis de segurança– Alto (recomendado a todos usuários)– Médio (para usuários experientes)– Baixo (para nenhum usuário !!)
Sistema de Authenticode
ActiveX - Segurança
O que é a Assinatura Digital ? Possui informações com relação a empresa e
autor que desenvolveram o ActiveX Questão de confiança no autor e na Microsoft Funciona muito bem para Intranets Alguns especialistas apostam nesta
tecnologia
Java Applet x ActiveX
Java roda em uma JVM Carregado toda vez que é acessado Maior segurança, menor flexibilidade e
funcionalidade Java é seguro ? Teoricamente não pode escrever no sistema
de arquivos do cliente e não se comunicam com aplicativos não-java
Java Applet x ActiveX
Bugs encontrados em algumas JVM, promovem alto grau de insegurança
Novas tendências
Firewalls são usados para proteger redes de ActiveX e Java Applet
Há o bloqueio do código sem haver algum tipo de inspeção de sua validae
Pouco prático e inflexível As tecnologias mudam Surgem os Firewalls inteligentes
Novas tendências
Baseiam-se no estado da comunicação Utilizam estados de comunicações passadas e o
estado da aplicação em si Armazenamento de estado Aprende com as comunicações passadas Avaliam as presentes e futuras Quando a origem é desconhecida, usa-se a
adivinhação
Conclusão
Não existe algo realmente seguro na Internet Há sempre um risco inerente Toda a sociedade perde com isto Não é dever do usuário distinguir
determinadas tecnologias De alguma forma tem que se possibilitar um
ambiente seguro ActiveX é um vilão ou herói?
Breve Histórico
Semelhança com Java, mas desenvolvido pela Netscape
Browsers que suportam JavaScript– Netscape Navigator (2.x, 3.x)– Netscape Comunicator (4.x)– Internet Explorer (3.x, 4.0)
Breve Histórico
Originalmente chamada de LiveScript, o código JavaScript é colocado diretamente no texto de um documento HTML
É visto como um comentário em browsers que não o interpretam
Dão uma funcionalidade adicional para página Web.
JavaScript prover uma funcionalidade incremental, ela é sintaticamente simples e menos poderosa que Java
“Brechas” conhecidas na segurança de JavaScript
JavaScript também tem uma história de problemas com segurança. Não como as “brechas” de Java, que potencialmente podem trocar dados no disco do usuário, as “brechas” de JavaScript geralmente envolvem a privacidade do usuário. Apesar de alguns bugs terem sidos resolvidos outros explodem a cada dia. O mais recente foi relatado em 16 de outubro de 1997.
Interceptação de arquivos
“Brecha” do IE 4.0 permitem um operador de um Web Site
remoto espionar o conteúdo de algum texto imagem ou arquivo HTML localizado na sua máquina ou um arquivo localizado em um servidor de arquivo.
Interceptação de arquivos
Firewalls não podem nos proteger contra este ataque e os browsers estão vulneráveis mesmo quando rodam no modo de “Alta Segurança”.
versão para Macintosh do IE 4.0 aparentemente não são afetadas.
Interceptação de arquivos
Descoberto pelo consultor alemão Ralf Hueskes e é conhecido como “Freiburg attack”
Quando o browser abre o site, o programa JavaScript cria um frame invisível e vai varrendo todos os arquivos da máquina em busca de arquivos de nomes bem conhecidos enviando-os para algum site na Internet
Este bug não permite que JavaScript modifique ou prejudique os arquivos.
Monitoração da Sessão do Usuário
Esta brecha permite que páginas com JavaScript monitore todas as páginas visitadas pelo usuário durante a sessão.
Variações: capturar conteúdo de formulários, cookies e informações sobre outros elementos na página.
Monitoração da Sessão do Usuário
Informações sempre podem ser roubadas mesmo se o usuário estiver visualizando páginas “seguras” encriptadas com SSL
Usuários trabalhando atrás de sistemas de Firewalls corporativos estão tão vulneráveis quanto aqueles que estão conectados diretamente na Internet
Risco: privacidade do usuário, dados e softwares localizados na máquina do usuário não podem ser modificados.
Todos os browsers estão sujeitos a este bug
Observação de Informações através de Frames
Um JavaScript não pode recuperar a URL de um documento baixado de um outro site, mas ele pode detectar os seguintes itens do respectivo documento
URLs de todas imagens no documento Outras informações das imagens, como
largura e comprimento URLs de todos os Applets URLs de todos os ActiveX Controls
“Brecha” de Enviar Arquivo
Não estritamente relacionada com JavaScript
Bug no modo em que formulários são tratados pelo Navigator
Programas JavaScript enganam o browser enviando algum arquivo do HD do usuário local
“Brecha” de Enviar Arquivo
O Usuário não terá conhecimento a não ser que tenha habilitado a opção de “Aviso antes de Submeter”
O Navigator falhará em produzir um aviso se o servidor remoto por acaso utilizar SSL para estabelecer uma conexão “segura”
Conclusão
JavaScript contém “brechas” na segurança. Muitas delas tem sido diagnosticadas, mas novas vem aparecendo numa taxa constante. Indubitavelmente ainda existem bugs desconhecidos. As pessoas que se preocupam com a falta de privacidade das informações são encorajadas a desabilitar JavaScript completamente.