Gracias por enviar su consulta! Uno de los miembros de nuestro equipo se pondrá en contacto con usted en breve.
Gracias por enviar su reserva! Uno de los miembros de nuestro equipo se pondrá en contacto con usted en breve.
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
Testimonios (3)
La experiencia compartida, el saber hacer del profesor y su valor son importantes.
Carey Fan - Logitech
Curso - C/C++ Secure Coding
Traducción Automática
el conocimiento del instructor era muy alto - sabía de lo que estaba hablando y conocía las respuestas a nuestras preguntas
Adam - Fireup.PRO
Curso - Advanced Java Security
Traducción Automática
El tema es actual y necesitaba estar al día
Damilano Marco - SIAP s.r.l.
Curso - Secure Developer Java (Inc OWASP)
Traducción Automática