Contacta con nosotros

Temario del curso

Día 1

Seguridad de TI y codificación segura

  • Naturaleza de la seguridad
  • Términos relacionados con la seguridad de TI
  • Definición de riesgo
  • Diferentes aspectos de la seguridad de TI
  • Requisitos de diferentes áreas de aplicación
  • Seguridad de TI vs. codificación segura
  • Desde vulnerabilidades hasta botnets y cibercrimen
    • Naturaleza de los fallos de seguridad
    • Razones de dificultad
    • De una computadora infectada a ataques dirigidos
  • Clasificación de fallos de seguridad
    • Taxonomía de Landwehr
    • Los Siete Reinos Perniciosos
    • OWASP Top Ten 2013
    • Comparación OWASP Top Ten 2003 - 2013

Introducción al Ciclo de Desarrollo Seguro (SDL) de Microsoft®

  • Agenda
  • Aplicaciones bajo ataque...
    • Evolución del cibercrimen
    • Los ataques se centran en las aplicaciones
    • La mayoría de las vulnerabilidades están en aplicaciones de ISV más pequeñas
  • Orígenes del SDL de Microsoft...
    • Línea de tiempo de seguridad en Microsoft...
    • ¿Qué aplicaciones deben seguir el SDL?
  • Ciclo de Desarrollo Seguro de Seguridad de Microsoft (SDL)
    • Ciclo de Desarrollo Seguro de Seguridad de Microsoft (SDL)
    • Requisitos previos al SDL: Entrenamiento en seguridad
    • Fase Uno: Requisitos
    • Fase Dos: Diseño
    • Fase Tres: Implementación
    • Fase Cuatro: Verificación
    • Fase Cinco: Lanzamiento - Plan de respuesta
    • Fase Cinco: Lanzamiento - Revisión final de seguridad
    • Fase Cinco: Lanzamiento - Archivo
    • Requisito posterior al SDL: Respuesta
    • Orientación del proceso SDL para aplicaciones LOB
    • Orientación del SDL para metodologías ágiles
    • El desarrollo seguro de software requiere mejora de procesos

Principios de diseño seguro

  • Superficie de ataque
    • Reducción de la superficie de ataque
    • Superficie de ataque - un ejemplo
    • Análisis de la superficie de ataque
    • Reducción de la superficie de ataque - ejemplos
  • Privacidad
    • Privacidad
    • Comprensión del comportamiento y preocupaciones de la aplicación
  • Defensa en profundidad
    • Principio fundamental del SDL: Defensa en profundidad
    • Defensa en profundidad - ejemplo
  • Principio de privilegio mínimo
    • Privilegio mínimo - ejemplo
  • Valores predeterminados seguros
    • Valores predeterminados seguros - ejemplos

Principios de implementación segura

  • Agenda
  • Ciclo de Desarrollo Seguro de Seguridad de Microsoft (SDL)
  • Conceptos básicos de desbordamiento de búfer
    • Procesadores Intel 80x86 - registros principales
    • Diseño del espacio de direcciones de memoria
    • El mecanismo de llamada de funciones en C/C++ en x86
    • Las variables locales y el marco de pila
    • Desbordamiento de pila
      • Desbordamiento de búfer en la pila
      • Ejercicios - introducción
      • Ejercicio BOFIntro
      • Ejercicio BOFIntro - determinar el diseño de la pila
      • Ejercicio BOFIntro - un exploit simple
  • Validación de entrada
    • Conceptos de validación de entrada
    • Problemas con enteros
      • Representación de enteros negativos
      • Desbordamiento de enteros
      • Desbordamiento aritmético - ¡adivina la salida!
      • Ejercicio IntOverflow
      • ¿Cuál es el valor de Math.Abs(int.MinValue)?
    • Mitigación de problemas con enteros
      • Mitigación de problemas con enteros
      • Evitar el desbordamiento aritmético - suma
      • Evitar el desbordamiento aritmético - multiplicación
      • Detección de desbordamiento con la palabra clave checked en C#
      • Ejercicio - Uso de la palabra clave checked en C#
      • Excepciones provocadas por desbordamientos en C#
    • Estudio de caso - Desbordamiento de enteros en .NET
      • Una vulnerabilidad de desbordamiento de enteros del mundo real
      • Explotando la vulnerabilidad de desbordamiento de enteros
    • Vulnerabilidad de travesía de rutas
      • Mitigación de la travesía de rutas

Día 2

Principios de implementación segura

  • Inyección
    • Métodos típicos de ataque de Inyección SQL
    • Inyección SQL ciega y basada en tiempo
    • Métodos de protección contra Inyección SQL
    • Inyección de comandos
  • Autenticación fallida - gestión de contraseñas
    • Ejercicio - Debilidad de las contraseñas hasheadas
    • Gestión y almacenamiento de contraseñas
    • Algoritmos de hash de propósito especial para el almacenamiento de contraseñas
  • Scripting entre sitios (XSS)
    • Scripting entre sitios (XSS)
    • Inyección CSS
    • Explotación: inyección a través de otras etiquetas HTML
    • Prevención de XSS
  • Control de acceso a nivel de función ausente
    • Filtrado de cargas de archivos
  • Criptografía práctica
    • Proporcionar confidencialidad con criptografía simétrica
    • Algoritmos de cifrado simétrico
    • Cifrados de bloque - modos de operación
    • Hash o resumen de mensaje
    • Algoritmos de hash
    • Código de autenticación de mensajes (MAC)
    • Proporcionar integridad y autenticidad con una clave simétrica
    • Proporcionar confidencialidad con cifrado de clave pública
    • Regla general - posesión de la clave privada
    • Errores típicos en la gestión de contraseñas
    • Ejercicio - Contraseñas codificadas en duro
    • Conclusión

Principios de verificación segura

  • Pruebas funcionales vs. pruebas de seguridad
  • Vulnerabilidades de seguridad
  • Priorización
  • Pruebas de seguridad en el SDLC
  • Pasos de la planificación de pruebas (análisis de riesgo)
  • Delimitación y recopilación de información
    • Partes interesadas
    • Activos
    • La superficie de ataque
    • Objetivos de seguridad para las pruebas
  • Modelado de amenazas
    • Modelado de amenazas
    • Perfiles de atacante
    • Modelado de amenazas basado en árboles de ataque
    • Modelado de amenazas basado en casos de uso indebido/abuso
    • Casos de uso indebido/abuso - un ejemplo simple de tienda web
    • Enfoque STRIDE por elemento para el modelado de amenazas - MS SDL
    • Identificación de objetivos de seguridad
    • Diagramación - ejemplos de elementos DFD
    • Diagrama de flujo de datos - ejemplo
    • Enumeración de amenazas - STRIDE de MS SDL y elementos DFD
    • Análisis de riesgo - clasificación de amenazas
    • El modelo de clasificación de amenazas/riesgo DREAD
  • Técnicas y herramientas de pruebas de seguridad
    • Enfoques generales de prueba
    • Técnicas para las diversas etapas del SDLC
  • Revisión de código
    • Revisión de código para la seguridad del software
    • Análisis de taint
    • Heurísticas
  • Análisis estático de código
    • Análisis estático de código
    • Ejercicio - Uso de herramientas de análisis estático de código
  • Pruebas de la implementación
    • Verificación manual en tiempo de ejecución
    • Pruebas de seguridad manuales vs. automatizadas
    • Pruebas de penetración
    • Pruebas de estrés
  • Fuzzing
    • Pruebas de seguridad automatizadas - fuzzing
    • Desafíos del fuzzing
  • Escáneres de vulnerabilidades web
    • Ejercicio - Uso de un escáner de vulnerabilidades
  • Verificación y endurecimiento del entorno
    • Sistema Común de Clasificación de Vulnerabilidades - CVSS
    • Escáneres de vulnerabilidades
    • Bases de datos públicas
  • Estudio de caso - Contorno de Autenticación de Formularios
    • Vulnerabilidad de terminación con byte nulo
    • La vulnerabilidad de contorno de Autenticación de Formularios en el código
    • Explotando el contorno de Autenticación de Formularios

Fuentes de conocimiento

  • Fuentes de codificación segura - un kit de inicio
  • Bases de datos de vulnerabilidades
  • Guías de codificación segura de .NET en MSDN
  • Hojas de referencia de codificación segura de .NET
  • Libros recomendados - .NET y ASP.NET
 14 Horas

Número de participantes


Precio por participante

Testimonios (3)

Próximos cursos

Categorías Relacionadas