Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Sistemas seguros em PHP

Sistemas seguros em PHP

Veremos como aplicar as melhores medidas para protegermos nossos sistemas, trazendo os principais itens do OWASP Top Ten de uma forma mais profunda, indo além dos exemplos mais comuns encontrados, que muitas vezes são resolvidos pelos próprios frameworks.
Pontos que serão abordados: enumeração de usuários, gerenciamento de sessão, melhores práticas de validação de entradas, runtime application self-protection, armazenamento e políticas de senhas.

Vinícius Campitelli

June 08, 2019
Tweet

More Decks by Vinícius Campitelli

Other Decks in Programming

Transcript

  1. Quem sou eu VINÍCIUS CAMPITELLI Membro do Desenvolvedor na Entusiasta

    em cibersegurança 10+ anos desenvolvendo em PHP PHPSP OTTera 2 . 1
  2. Quem sou eu Slides & GitHub Twitter LinkedIn vcampitelli vcampitelli

    vcampitelli vcampitelli Vinícius Vinícius Campitelli Campitelli 2 . 2
  3. Agenda OWASP Top Ten Gerenciamento de sessão Validação de entradas

    Armazenamento e políticas de senhas Enumeração de usuários Referências 3
  4. Regere o ID da sessão no login e logout para

    mitigar Session Fixation if if ( ($user $user = = $this $this-> ->loginFrom loginFrom( ($_POST $_POST) )) ) { { session_start session_start( () ); ; session_regenerate_id session_regenerate_id( (true true) ); ; // true para apagar a sess // true para apagar a sess } } 5 . 3
  5. Com , podemos ter certificados SSL gratuitos ♥ Uso e

    recomendo o Let's Encrypt Lista de clientes suportados acme.sh 5 . 6
  6. Configurações do PHP session.cookie_domain session.cookie_domain= =" "meusite.com.br meusite.com.br" " session.cookie_httponly

    session.cookie_httponly= =On On session.cookie_samesite session.cookie_samesite= =" "Strict Strict" " session.cookie_secure session.cookie_secure= =On On session.name session.name= =" "MYSESSNAME MYSESSNAME" " session.sid_bits_per_character session.sid_bits_per_character= =6 6 session.sid_length session.sid_length= =48 48 session.use_only_cookies session.use_only_cookies= =On On session.use_strict_mode session.use_strict_mode= =On On session.use_trans_sid session.use_trans_sid= =Off Off 5 . 7
  7. Referências Paragon IE - The Fast Track to Safe and

    Secure PHP Sessions Manual do PHP - Securing Session INI Settings 5 . 8
  8. Nunca confie em entradas do usuário! “Mas eu estou validando

    no frontend!” — Alguém antes de ter sua aplicação invadida 6 . 2
  9. Você pode utilizar filtros de XSS na entrada Mas deve

    tratar a saída Se usar uma ferramenta de templating, verifique sua própria função Senão, use a função nativa: HTML Purifier voku/anti-xss htmlentities htmlentities( ($str $str, , ENT_QUOTES ENT_QUOTES | | ENT_HTML5 ENT_HTML5, , $encoding $encoding) ) 6 . 3
  10. Valide os dados de entrada de acordo com o que

    você espera para aquele campo (data type) Exemplo: um nome de uma pessoa pode ter apenas letras, espaços, números, hífen e apóstrofo (não esqueça dos acentos!) 6 . 4
  11. Crie uma camada em seu framework que irá validar todos

    os dados da requisição antes de chegar à camada de negócio Se um campo não possuir um data type estipulado, remova-o da requisição 6 . 5
  12. Você pode optar por duas abordagens 1. Sanitizar a entrada

    e seguir o processamento com o valor limpo; ou 2. Parar o processamento com HTTP 400 Bad Request (recomendado para aplicações críticas) 6 . 6
  13. Políticas Não limite os caracteres permitidos Não coloque um tamanho

    máximo O tamanho mínimo pode variar de acordo com as necessidades de sua aplicação (de acordo com o , 10 caracteres é o desejável) Crie mecanismos de complexidade Exemplo: ao menos 1 caractere maiúsculo, 1 minúsculo, 1 número e 1 caractere especial NIST SP800-132 7 . 2
  14. Armazenamento Aplique um algoritmo de hash para transformá-la em um

    texto com tamanho fixo Utilize um salt específico para aquela senha Criptografe o hash gerado para garantir que você possa recriptografar todas as senhas caso haja vazamento do banco de dados 7 . 3
  15. Se possível, use a ! Uma biblioteca segura, moderna e

    fácil de usar... libsodium 7 . 4
  16. Se possível, use a ! Uma biblioteca segura, moderna e

    fácil de usar... libsodium (por mais que os métodos sejam um pouco verbosos) 7 . 4
  17. Se possível, use a ! Uma biblioteca segura, moderna e

    fácil de usar... libsodium (por mais que os métodos sejam um pouco verbosos) Sim, estou de olho em você, sodium_crypto_sign_keypair_from_secretkey_and_publi 7 . 4
  18. Referências OWASP Authentication Cheat Sheet OWASP Password Storage Cheat Sheet

    CrackStation: Salted Password Hashing - Doing it Right paragonie/password_lock Slides da minha palestra sobre a libsodium Wikipedia: Rainbow Tables 7 . 5
  19. O que um sistema que rode o código a seguir

    pode dar de informação a um atacante? 8 . 1
  20. public public function function login login( (string string $username $username,

    , string string $password $password) ) { { $user $user = = $this $this-> ->findByUsername findByUsername( ($username $username) ); ; if if ( (! ! $user $user) ) { { return return false false; ; } } if if ( (! ! $this $this-> ->verifyPassword verifyPassword( ($password $password, , $user $user-> ->getPasswo getPasswo return return false false; ; } } return return true true; ; } } 8 . 2
  21. Enumeração de usuários É possível saber que usuários existem em

    sua aplicação através de Timing attacks 8 . 3
  22. public public function function login login( (string string $username $username,

    , string string $password $password) ) { { $storedPassword $storedPassword = = $this $this-> ->generateFakePassword generateFakePassword( () ); ; $user $user = = $this $this-> ->findByUsername findByUsername( ($username $username) ); ; if if ( ($user $user) ) { { $storedPassword $storedPassword = = $user $user-> ->getPassword getPassword( () ); ; } } return return ( ($this $this-> ->verifyPassword verifyPassword( ($password $password, , $storedPasswor $storedPasswor && && ( ($user $user !== !== null null) ); ; } } 8 . 4
  23. Será que não estamos exagerando? É realmente possível ver essa

    diferença? Vamos testar, então! Executando os scripts login-user-enumeration.php e login-user-enumeration-fixed.php 8 . 5
  24. Pontos de atenção Proteger uma aplicação Web não é algo

    trivial Existem muitos outros ataques e técnicas de defesas além dessas Avalie o que faz sentido para seu sistema Utilize técnicas de defesa em camadas 10