360 likes | 434 Views
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
E N D
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.