Carregar apresentação
A apresentação está carregando. Por favor, espere
PublicouFrancisco Carrico Alterado mais de 9 anos atrás
1
Sistemas Seguros Criptografia Simétrica e Assimétrica
Prof. Paulo Fernando da Silva
2
Criptografia Conceitos Básicos; Criptografia Simétrica;
Algoritmos Simétricos; Criptografia Assimétrica; Algoritmos Assimétricos; Hash e algoritmos; Assinatura digital;
3
Conceitos Básicos Criptografia é a ciência da escrita secreta;
É a base para a implementação de vários serviços de segurança; Um dos primeiros algoritmos é o cifrador de césar: Y = E(X) = x+3; X = D(Y) = x-3;
4
Conceitos Básicos
5
Conceitos Básicos Crifrador de césar não possui chave;
A força está no algoritmo; A chave tira a responsabilidade do algoritmo; Chave é um seletor de algoritmos; Como seria o cifrador de césar sem chave?
6
Conceitos Básicos
7
Conceitos Básicos
8
Criptografia Simétrica
Usam a mesma chave para cifrar e decifrar; Também chamados de algoritmos de chave secreta; São algoritmos geralmente rápidos;
9
Criptografia Simétrica
10
Criptografia Simétrica
Segurança se baseia na qualidade do algoritmo; Também no tamanho de chave; Segurança não se baseia no conhecimento do algoritmo;
11
Criptografia Simétrica
Possui um problema sério na distribuição de chave; A chave deve ser compartilhada, mas deve ser secreta; Para um grupo de n participantes, serão necessárias n(n-1)/2 chave distintas;
12
Criptografia Simétrica
13
Algoritmos Simétricos
DES; 3DES ou DES-EDE; IDEA; Blowfish; Cast-128; RC6; AES: atual padrão americano;
14
Algortimos Simétricos
Segurança está: Tamanho de chave; Princípio do confusão: complexidade entre texto cifrado e chave; Princípio da difusão: complexidade entre o texto plano e chave;
15
Algoritmo DES Tamanho de bloco de 64 bits e chave de 56 bits;
O DES tem 16 rounds; São geradas 16 sub-chaves, uma para cada rodada;
16
Algoritmo 3DES Utiliza duas chaves da seguinte maneira: Para decifrar:
Encripta com K1; Decripta com K2; Encripta novamente com K1; Para decifrar: Decripta com K1; Encripta com K2; Decripta novamente com K1;
17
Algoritmo AES Governo americano fez concurso para eleger novo algoritmo; Vencedor em 2001 foi o Rijndael; Mudou de nome para AES; Padronizado na FIPS PUB 197; Blocos de 128 bits; Chave de 128, 192 ou 256 bits;
18
Algoritmos Simétricos
IDEA: Bloco 64 bits; Chave 128 bits; Livre apenas para uso não comercial; RC6: Bloco e chave variável até 255bits; Número de rodadas variável;
19
Testar exemplo... Exemplo do DESCipher.java
20
Criptografia Assimétrica
Criado em 1976 por Dffie & Hellman; Também conhecido como criptografia de chave pública; Motivado pelo problema de distribuição de chaves simétricas;
21
Criptografia Assimétrica
Usa uma chave pública e ou chave privada; As chaves formam um par e trabalham em conjunto; O que uma chave cifra a outra chave decifra;
22
Criptografia Assimétrica
A chave pública todos podem conhecer; A chave privada apenas o dono pode conhecer; Função de chaves: f(x) = y; Conhecendo y é muito difícil descobrir o valor de x; Baseado na complexidade matemática;
23
Criptografia Assimétrica
24
Criptografia Assimétrica
Fornece serviços de confidencialidade e autenticidade; Autenticidade quando a origem cifra com sua chave privada; Confidencialidade quando a origem cifra com a chave pública do destino;
25
Criptografia Assimétrica
26
Criptografia Assimétrica
27
Criptografia Assimétrica
28
Criptografia Assimétrica
29
Criptografia Assimétrica
30
Algoritmos Assimétricos
Como fazer um algoritmo assimétrico válido? Usam duas técnicas: Aritmética exponencial modular; Curvas elípticas;
31
Algoritmos Assimétricos
Dois algoritmos mais conhecidos: RSA e ElGamal; Algoritmos RSA: É o mais usado comercialmente; Cifra blocos de tamanho variado = n;
32
Algoritmo RSA O par de chaves é derivado de n;
n é um número muito grande; n é resultado de dois números primos muito grandes = p & q; p & q devem ter mais de 100 dígitos cada um;
33
Algoritmo RSA Um invasor pode conhecer a chave pública e o número n;
Mas não conhece p & q; Logo ele não consegue gerar a chave privada;
34
Algoritmo RSA Escolher dois números primos grandes (> 10^100) p e q
Calcular n = p * q Escolher um número “e” relativamente primo com (p – 1) * (q – 1) Calcular d de forma que e * d = 1 mod (p – 1) * (q – 1), isto é, d = e-1 mod (p – 1) * (q – 1) Publicar (n, e) – chave pública, manter (n, d) – chave privada – e p, q em segredo
35
Algoritmo RSA KU = {e, n} KR = {d, n} Cifrar: M^e mod n
Decifrar: C^d mod n Invasor não consegue descobrir “d” a partir de “e” e “n”
36
Algoritmo RSA p= 7 e q = 17; n = 119; Totiente de n = 96;
e relativamente primo a 96 = 5; d = 77; KU = {5, 119} KR = {77,119}
37
Algoritmo RSA KU = {5, 119} KR = {77, 119} M = 19
Cifrar: 19^5 mod 119 = 66 C = 66 Decifrar: 66^77 mod 119 = 19 Obs: na prática a chave é bem maior, mais de 130 dígitos;
38
Testar exemplo... Exemplo Cifra RSA
39
Hash e algoritmos Funções hash, ou message digests ou funções one-way;
Função hash: y = f(x); y é facilmente calculado; x é computacionalmente complexo;
40
Hash e algoritmos Uma função hash gera um resumo de sua entrada;
A partir do resumo não deve ser possível encontrar-se a entrada; Não deve ser possível encontrar uma entrada que gere um resumo específico;
41
Hash e algoritmos É usado para gerar impressão digital de arquivos (por exemplo); Também é usado em certificados e assinatura digital;
42
Hash e algoritmos Alguns algoritmos são: MD5, SHA-1, SHA-2 ou SHA-256;
SHA é o padrão do NIST; SHA-224, 256, 384 e 512;
43
Hash e algoritmos
44
Testar exemplo... Exemplo resumo.java
45
Assinatura Digital A criptografia assimétrica permite a implementação de assinatura digital; Assinar é cifrar algo com a chave privada; Assinar toda a informação a ser enviada é um processo muito caro computacionalmente;
46
Assinatura Digital M E D KRa EKRa(M) Fonte Destino KUa
47
Assinatura Digital É necessário cifrar todo o conteúdo para garantir a origem?
48
Assinatura Digital Não!!! Basta cifrar apenas o hash do conteúdo;
O hash irá garantir a autenticidade e a integridade de todo o conteúdo;
49
Assinatura Digital – Transmissão
50
Assinatura Digital – Recepção
51
Assinatura com DSS
52
Testar Exemplo... Exemplo assinatura.java
Apresentações semelhantes
© 2024 SlidePlayer.com.br Inc.
All rights reserved.