SCW图标
英雄背景无分隔线
博客

Los codificadores conquistan la seguridad: serie Share & Learn - Inyección de código

Jaap Karan Singh
发表于 2019 年 5 月 16 日
最后更新于 2026年3月6日

Los ataques de inyección de código se encuentran entre los más comunes, y también los más peligrosos, con los que se encontrarán muchos sitios web y aplicaciones. Abarcan toda la gama, tanto en términos de sofisticación como del peligro que representan, pero casi cualquier sitio o aplicación que acepte la entrada de los usuarios podría ser vulnerable. De hecho, casi todos los defensores de la ciberseguridad tendrán que enfrentarse a este tipo de ataque en algún momento de su carrera, y es probable que se enfrenten a él varias veces.

Se puede producir un ataque de inyección de código siempre que una aplicación o un sitio web acepte la entrada de los usuarios. Esto puede ser tan sencillo como proporcionar una función de búsqueda o pedirle a un usuario que introduzca su información de identificación. El ataque ocurre cuando un usuario malintencionado introduce código en el campo abierto en lugar de introducir texto normal. Su objetivo es hacer que el servidor confunda la entrada con un código válido y, a continuación, ejecutar las funciones que el atacante desee.

Si bien los ataques de inyección de código son extremadamente comunes, también lo son las defensas disponibles que se pueden usar para detenerlos. En este episodio, aprenderemos lo siguiente:

  • Cómo funcionan
  • Por qué son tan peligrosos
  • Cómo puedes establecer defensas para detenerlos.

¿Cómo utilizan los atacantes la inyección de código?

Si bien los detalles específicos sobre los ataques de inyección de código cambian según el lenguaje de programación utilizado, cualquier aplicación o sitio web puede ser vulnerable siempre que permita al usuario introducir datos. Se han activado ataques de inyección de código para SQL, HTML, XML, CSS y cualquier otro lenguaje de programación común.

En primer lugar, un atacante debe localizar el código vulnerable dentro de una aplicación, normalmente en un punto en el que los usuarios pueden introducir sus propios datos. Por ejemplo, este código toma la función eval () de PHP y la pasa a un usuario para que la modifique, sin ningún tipo de validación de la cadena devuelta.

$myvar = «varname»;
$x = $_GET [argumento];
eval («\ $myvar =\ $x;»);

Un atacante inteligente podría añadir fácilmente su propia cadena a la función eval e incluso ejecutar comandos del sistema si así lo desea.

/index.php? arg=1; sistema (id)

Es importante tener en cuenta que, si bien los ataques de inyección de código pueden implicar el envío de comandos del sistema, no se limitan a hacerlo. De hecho, en los ataques de inyección de código, los piratas informáticos solo están limitados por la funcionalidad del lenguaje en sí. En nuestro ejemplo, un atacante podría programar el sistema objetivo para que hiciera casi cualquier cosa permitida por el marco PHP.

¿Por qué son tan peligrosos los ataques de inyección de código?

Los ataques de inyección de código son potencialmente extremadamente peligrosos según la habilidad del atacante. Pueden hacer cualquier cosa que el lenguaje de programación les permita, lo que los coloca en pie de igualdad con los programadores de la aplicación. Un atacante podría prácticamente escribir su propia aplicación y hacer que se ejecute en el entorno objetivo.

Incluso los atacantes menos hábiles pueden ser peligrosos. En lugar de escribir su propia aplicación o cadenas de código, pueden simplemente ordenar al sistema objetivo que acepte e instale malware preprogramado. Esto podría provocar la desfiguración del sitio, ataques de ransomware o incluso convertirse en la base de una campaña de suplantación de identidad dirigida contra los usuarios del sitio.

La mayoría de las veces, los ataques de inyección de código se utilizan para robar cosas como listas de usuarios y contraseñas, o para obtener un valioso reconocimiento de un sistema que se ve amenazado aún más. Sin embargo, ten en cuenta que un programador experto puede hacer casi cualquier cosa ante un ataque de inyección de código, por lo que es fundamental que se descubran todos los posibles casos en los que se produzca y se eliminen del entorno.

¡No confíes en nadie! (O al menos, no los usuarios)

Al eliminar las vulnerabilidades de los ataques de inyección de código, lo primero que hay que buscar es cualquier lugar que solicite o permita la entrada del usuario. No se puede confiar en nada que introduzca un usuario bajo ninguna circunstancia. Si permites la entrada de los usuarios sin filtrar ni examinar, básicamente estás invitando a los atacantes a que intenten poner en peligro tu sistema o incluso tu red.

Aunque no siempre es posible, la mejor manera de frustrar los ataques de inyección de código es impedir que las funciones ejecuten o interpreten directamente las entradas del usuario. Es posible que los usuarios puedan elegir entre opciones estáticas en lugar de tener libertad para introducir sus propias consultas, programando la aplicación para que solo acepte esas opciones limitadas como válidas. Puede que no siempre sea apropiado hacerlo, pero usarlo siempre que sea posible puede eliminar las inyecciones de código antes de que comiencen.

En las áreas en las que los usuarios deben introducir sus propias entradas, se deben aplicar controles estrictos a esos datos. Asumir que todo es un posible ataque es un buen punto de partida. La aplicación de políticas de privilegios mínimos, como el acceso de usuario de solo lectura, tanto en el lado del cliente como del servidor, puede impedir la ejecución de la mayor parte del código.

La otra buena defensa es implementar filtros en toda la aplicación y desinfectar todo lo que introduzca el usuario. Los desarrolladores conocen los ataques por inyección de código desde hace años, y existen bibliotecas de filtros comprobados para cada marco y lenguaje. Cuando apliques esos filtros, asegúrate de hacerlo no solo en las áreas de entrada obvias de los usuarios o en función de parámetros comunes, como los comandos Get y Post, sino también en función de las cookies y los encabezados HTTP.

Aplicación de una corrección para la inyección de código

Eliminar las áreas de entrada de usuario innecesarias de su entorno, aplicar los principios de mínimo privilegio y utilizar las herramientas de filtrado y desinfección más recientes para inspeccionar y detectar posibles ataques puede cerrar la puerta a esta peligrosa vulnerabilidad. Tener la mentalidad de no confiar nunca en las opiniones de los usuarios también le servirá de mucho para seguir adelante. Haz todo eso y podrás ir un paso por delante de este peligroso tipo de ataque.

Para leer más, puede echar un vistazo al OWASP artículo sobre inyección de código. También puedes poner a prueba tus nuevos conocimientos defensivos con el demo gratuita de la plataforma Secure Code Warrior, que forma a los equipos de ciberseguridad para que se conviertan en los mejores ciberguerreros. Para obtener más información sobre cómo derrotar esta vulnerabilidad y la galería de otras amenazas de los delincuentes, visita la Blog de Secure Code Warrior.

Inyección frontal de código, ahora mismo. Acepta el desafío en nuestra plataforma de formación gamificada: [Empieza aquí]

查看资源
查看资源

Los ataques de inyección de código se encuentran entre los más comunes, y también los más peligrosos, con los que se encontrarán muchos sitios web y aplicaciones. Abarcan toda la gama, tanto en términos de sofisticación como del peligro que representan, pero casi cualquier sitio o aplicación que acepte la entrada de los usuarios podría ser vulnerable.

感兴趣了解更多吗?

Jaap Karan Singh是一位安全编码布道者,首席辛格和Secure Code Warrior 的共同创始人。

了解更多

Secure Code Warrior 您的组织在软件开发全生命周期中保护代码安全,并营造将网络安全置于首位的企业文化。无论您是应用安全管理员、开发人员、首席信息安全官,还是任何与安全相关的工作人员,我们都能助力您的组织降低不安全代码带来的风险。

预约演示
分享到:
领英品牌社交x 标志
作者
Jaap Karan Singh
2019年5月16日发布

Jaap Karan Singh是一位安全编码布道者,首席辛格和Secure Code Warrior 的共同创始人。

分享到:
领英品牌社交x 标志

Los ataques de inyección de código se encuentran entre los más comunes, y también los más peligrosos, con los que se encontrarán muchos sitios web y aplicaciones. Abarcan toda la gama, tanto en términos de sofisticación como del peligro que representan, pero casi cualquier sitio o aplicación que acepte la entrada de los usuarios podría ser vulnerable. De hecho, casi todos los defensores de la ciberseguridad tendrán que enfrentarse a este tipo de ataque en algún momento de su carrera, y es probable que se enfrenten a él varias veces.

Se puede producir un ataque de inyección de código siempre que una aplicación o un sitio web acepte la entrada de los usuarios. Esto puede ser tan sencillo como proporcionar una función de búsqueda o pedirle a un usuario que introduzca su información de identificación. El ataque ocurre cuando un usuario malintencionado introduce código en el campo abierto en lugar de introducir texto normal. Su objetivo es hacer que el servidor confunda la entrada con un código válido y, a continuación, ejecutar las funciones que el atacante desee.

Si bien los ataques de inyección de código son extremadamente comunes, también lo son las defensas disponibles que se pueden usar para detenerlos. En este episodio, aprenderemos lo siguiente:

  • Cómo funcionan
  • Por qué son tan peligrosos
  • Cómo puedes establecer defensas para detenerlos.

¿Cómo utilizan los atacantes la inyección de código?

Si bien los detalles específicos sobre los ataques de inyección de código cambian según el lenguaje de programación utilizado, cualquier aplicación o sitio web puede ser vulnerable siempre que permita al usuario introducir datos. Se han activado ataques de inyección de código para SQL, HTML, XML, CSS y cualquier otro lenguaje de programación común.

En primer lugar, un atacante debe localizar el código vulnerable dentro de una aplicación, normalmente en un punto en el que los usuarios pueden introducir sus propios datos. Por ejemplo, este código toma la función eval () de PHP y la pasa a un usuario para que la modifique, sin ningún tipo de validación de la cadena devuelta.

$myvar = «varname»;
$x = $_GET [argumento];
eval («\ $myvar =\ $x;»);

Un atacante inteligente podría añadir fácilmente su propia cadena a la función eval e incluso ejecutar comandos del sistema si así lo desea.

/index.php? arg=1; sistema (id)

Es importante tener en cuenta que, si bien los ataques de inyección de código pueden implicar el envío de comandos del sistema, no se limitan a hacerlo. De hecho, en los ataques de inyección de código, los piratas informáticos solo están limitados por la funcionalidad del lenguaje en sí. En nuestro ejemplo, un atacante podría programar el sistema objetivo para que hiciera casi cualquier cosa permitida por el marco PHP.

¿Por qué son tan peligrosos los ataques de inyección de código?

Los ataques de inyección de código son potencialmente extremadamente peligrosos según la habilidad del atacante. Pueden hacer cualquier cosa que el lenguaje de programación les permita, lo que los coloca en pie de igualdad con los programadores de la aplicación. Un atacante podría prácticamente escribir su propia aplicación y hacer que se ejecute en el entorno objetivo.

Incluso los atacantes menos hábiles pueden ser peligrosos. En lugar de escribir su propia aplicación o cadenas de código, pueden simplemente ordenar al sistema objetivo que acepte e instale malware preprogramado. Esto podría provocar la desfiguración del sitio, ataques de ransomware o incluso convertirse en la base de una campaña de suplantación de identidad dirigida contra los usuarios del sitio.

La mayoría de las veces, los ataques de inyección de código se utilizan para robar cosas como listas de usuarios y contraseñas, o para obtener un valioso reconocimiento de un sistema que se ve amenazado aún más. Sin embargo, ten en cuenta que un programador experto puede hacer casi cualquier cosa ante un ataque de inyección de código, por lo que es fundamental que se descubran todos los posibles casos en los que se produzca y se eliminen del entorno.

¡No confíes en nadie! (O al menos, no los usuarios)

Al eliminar las vulnerabilidades de los ataques de inyección de código, lo primero que hay que buscar es cualquier lugar que solicite o permita la entrada del usuario. No se puede confiar en nada que introduzca un usuario bajo ninguna circunstancia. Si permites la entrada de los usuarios sin filtrar ni examinar, básicamente estás invitando a los atacantes a que intenten poner en peligro tu sistema o incluso tu red.

Aunque no siempre es posible, la mejor manera de frustrar los ataques de inyección de código es impedir que las funciones ejecuten o interpreten directamente las entradas del usuario. Es posible que los usuarios puedan elegir entre opciones estáticas en lugar de tener libertad para introducir sus propias consultas, programando la aplicación para que solo acepte esas opciones limitadas como válidas. Puede que no siempre sea apropiado hacerlo, pero usarlo siempre que sea posible puede eliminar las inyecciones de código antes de que comiencen.

En las áreas en las que los usuarios deben introducir sus propias entradas, se deben aplicar controles estrictos a esos datos. Asumir que todo es un posible ataque es un buen punto de partida. La aplicación de políticas de privilegios mínimos, como el acceso de usuario de solo lectura, tanto en el lado del cliente como del servidor, puede impedir la ejecución de la mayor parte del código.

La otra buena defensa es implementar filtros en toda la aplicación y desinfectar todo lo que introduzca el usuario. Los desarrolladores conocen los ataques por inyección de código desde hace años, y existen bibliotecas de filtros comprobados para cada marco y lenguaje. Cuando apliques esos filtros, asegúrate de hacerlo no solo en las áreas de entrada obvias de los usuarios o en función de parámetros comunes, como los comandos Get y Post, sino también en función de las cookies y los encabezados HTTP.

Aplicación de una corrección para la inyección de código

Eliminar las áreas de entrada de usuario innecesarias de su entorno, aplicar los principios de mínimo privilegio y utilizar las herramientas de filtrado y desinfección más recientes para inspeccionar y detectar posibles ataques puede cerrar la puerta a esta peligrosa vulnerabilidad. Tener la mentalidad de no confiar nunca en las opiniones de los usuarios también le servirá de mucho para seguir adelante. Haz todo eso y podrás ir un paso por delante de este peligroso tipo de ataque.

Para leer más, puede echar un vistazo al OWASP artículo sobre inyección de código. También puedes poner a prueba tus nuevos conocimientos defensivos con el demo gratuita de la plataforma Secure Code Warrior, que forma a los equipos de ciberseguridad para que se conviertan en los mejores ciberguerreros. Para obtener más información sobre cómo derrotar esta vulnerabilidad y la galería de otras amenazas de los delincuentes, visita la Blog de Secure Code Warrior.

Inyección frontal de código, ahora mismo. Acepta el desafío en nuestra plataforma de formación gamificada: [Empieza aquí]

查看资源
查看资源

请填写以下表格以下载报告

我们希望获得您的许可,以便向您发送有关我们产品或安全编码相关主题的信息。我们将始终以最高标准谨慎处理您的个人数据,绝不会出于营销目的将其出售给其他公司。

发送
scw 成功图标
SCW 错误图标
要提交表单,请启用「分析」cookie。完成后请随时将其重新禁用。

Los ataques de inyección de código se encuentran entre los más comunes, y también los más peligrosos, con los que se encontrarán muchos sitios web y aplicaciones. Abarcan toda la gama, tanto en términos de sofisticación como del peligro que representan, pero casi cualquier sitio o aplicación que acepte la entrada de los usuarios podría ser vulnerable. De hecho, casi todos los defensores de la ciberseguridad tendrán que enfrentarse a este tipo de ataque en algún momento de su carrera, y es probable que se enfrenten a él varias veces.

Se puede producir un ataque de inyección de código siempre que una aplicación o un sitio web acepte la entrada de los usuarios. Esto puede ser tan sencillo como proporcionar una función de búsqueda o pedirle a un usuario que introduzca su información de identificación. El ataque ocurre cuando un usuario malintencionado introduce código en el campo abierto en lugar de introducir texto normal. Su objetivo es hacer que el servidor confunda la entrada con un código válido y, a continuación, ejecutar las funciones que el atacante desee.

Si bien los ataques de inyección de código son extremadamente comunes, también lo son las defensas disponibles que se pueden usar para detenerlos. En este episodio, aprenderemos lo siguiente:

  • Cómo funcionan
  • Por qué son tan peligrosos
  • Cómo puedes establecer defensas para detenerlos.

¿Cómo utilizan los atacantes la inyección de código?

Si bien los detalles específicos sobre los ataques de inyección de código cambian según el lenguaje de programación utilizado, cualquier aplicación o sitio web puede ser vulnerable siempre que permita al usuario introducir datos. Se han activado ataques de inyección de código para SQL, HTML, XML, CSS y cualquier otro lenguaje de programación común.

En primer lugar, un atacante debe localizar el código vulnerable dentro de una aplicación, normalmente en un punto en el que los usuarios pueden introducir sus propios datos. Por ejemplo, este código toma la función eval () de PHP y la pasa a un usuario para que la modifique, sin ningún tipo de validación de la cadena devuelta.

$myvar = «varname»;
$x = $_GET [argumento];
eval («\ $myvar =\ $x;»);

Un atacante inteligente podría añadir fácilmente su propia cadena a la función eval e incluso ejecutar comandos del sistema si así lo desea.

/index.php? arg=1; sistema (id)

Es importante tener en cuenta que, si bien los ataques de inyección de código pueden implicar el envío de comandos del sistema, no se limitan a hacerlo. De hecho, en los ataques de inyección de código, los piratas informáticos solo están limitados por la funcionalidad del lenguaje en sí. En nuestro ejemplo, un atacante podría programar el sistema objetivo para que hiciera casi cualquier cosa permitida por el marco PHP.

¿Por qué son tan peligrosos los ataques de inyección de código?

Los ataques de inyección de código son potencialmente extremadamente peligrosos según la habilidad del atacante. Pueden hacer cualquier cosa que el lenguaje de programación les permita, lo que los coloca en pie de igualdad con los programadores de la aplicación. Un atacante podría prácticamente escribir su propia aplicación y hacer que se ejecute en el entorno objetivo.

Incluso los atacantes menos hábiles pueden ser peligrosos. En lugar de escribir su propia aplicación o cadenas de código, pueden simplemente ordenar al sistema objetivo que acepte e instale malware preprogramado. Esto podría provocar la desfiguración del sitio, ataques de ransomware o incluso convertirse en la base de una campaña de suplantación de identidad dirigida contra los usuarios del sitio.

La mayoría de las veces, los ataques de inyección de código se utilizan para robar cosas como listas de usuarios y contraseñas, o para obtener un valioso reconocimiento de un sistema que se ve amenazado aún más. Sin embargo, ten en cuenta que un programador experto puede hacer casi cualquier cosa ante un ataque de inyección de código, por lo que es fundamental que se descubran todos los posibles casos en los que se produzca y se eliminen del entorno.

¡No confíes en nadie! (O al menos, no los usuarios)

Al eliminar las vulnerabilidades de los ataques de inyección de código, lo primero que hay que buscar es cualquier lugar que solicite o permita la entrada del usuario. No se puede confiar en nada que introduzca un usuario bajo ninguna circunstancia. Si permites la entrada de los usuarios sin filtrar ni examinar, básicamente estás invitando a los atacantes a que intenten poner en peligro tu sistema o incluso tu red.

Aunque no siempre es posible, la mejor manera de frustrar los ataques de inyección de código es impedir que las funciones ejecuten o interpreten directamente las entradas del usuario. Es posible que los usuarios puedan elegir entre opciones estáticas en lugar de tener libertad para introducir sus propias consultas, programando la aplicación para que solo acepte esas opciones limitadas como válidas. Puede que no siempre sea apropiado hacerlo, pero usarlo siempre que sea posible puede eliminar las inyecciones de código antes de que comiencen.

En las áreas en las que los usuarios deben introducir sus propias entradas, se deben aplicar controles estrictos a esos datos. Asumir que todo es un posible ataque es un buen punto de partida. La aplicación de políticas de privilegios mínimos, como el acceso de usuario de solo lectura, tanto en el lado del cliente como del servidor, puede impedir la ejecución de la mayor parte del código.

La otra buena defensa es implementar filtros en toda la aplicación y desinfectar todo lo que introduzca el usuario. Los desarrolladores conocen los ataques por inyección de código desde hace años, y existen bibliotecas de filtros comprobados para cada marco y lenguaje. Cuando apliques esos filtros, asegúrate de hacerlo no solo en las áreas de entrada obvias de los usuarios o en función de parámetros comunes, como los comandos Get y Post, sino también en función de las cookies y los encabezados HTTP.

Aplicación de una corrección para la inyección de código

Eliminar las áreas de entrada de usuario innecesarias de su entorno, aplicar los principios de mínimo privilegio y utilizar las herramientas de filtrado y desinfección más recientes para inspeccionar y detectar posibles ataques puede cerrar la puerta a esta peligrosa vulnerabilidad. Tener la mentalidad de no confiar nunca en las opiniones de los usuarios también le servirá de mucho para seguir adelante. Haz todo eso y podrás ir un paso por delante de este peligroso tipo de ataque.

Para leer más, puede echar un vistazo al OWASP artículo sobre inyección de código. También puedes poner a prueba tus nuevos conocimientos defensivos con el demo gratuita de la plataforma Secure Code Warrior, que forma a los equipos de ciberseguridad para que se conviertan en los mejores ciberguerreros. Para obtener más información sobre cómo derrotar esta vulnerabilidad y la galería de otras amenazas de los delincuentes, visita la Blog de Secure Code Warrior.

Inyección frontal de código, ahora mismo. Acepta el desafío en nuestra plataforma de formación gamificada: [Empieza aquí]

观看网络研讨会
开始
了解更多

点击下方链接,下载此资源的PDF文件。

Secure Code Warrior 您的组织在软件开发全生命周期中保护代码安全,并营造将网络安全置于首位的企业文化。无论您是应用安全管理员、开发人员、首席信息安全官,还是任何与安全相关的工作人员,我们都能助力您的组织降低不安全代码带来的风险。

查看报告预约演示
查看资源
分享到:
领英品牌社交x 标志
感兴趣了解更多吗?

分享到:
领英品牌社交x 标志
作者
Jaap Karan Singh
2019年5月16日发布

Jaap Karan Singh是一位安全编码布道者,首席辛格和Secure Code Warrior 的共同创始人。

分享到:
领英品牌社交x 标志

Los ataques de inyección de código se encuentran entre los más comunes, y también los más peligrosos, con los que se encontrarán muchos sitios web y aplicaciones. Abarcan toda la gama, tanto en términos de sofisticación como del peligro que representan, pero casi cualquier sitio o aplicación que acepte la entrada de los usuarios podría ser vulnerable. De hecho, casi todos los defensores de la ciberseguridad tendrán que enfrentarse a este tipo de ataque en algún momento de su carrera, y es probable que se enfrenten a él varias veces.

Se puede producir un ataque de inyección de código siempre que una aplicación o un sitio web acepte la entrada de los usuarios. Esto puede ser tan sencillo como proporcionar una función de búsqueda o pedirle a un usuario que introduzca su información de identificación. El ataque ocurre cuando un usuario malintencionado introduce código en el campo abierto en lugar de introducir texto normal. Su objetivo es hacer que el servidor confunda la entrada con un código válido y, a continuación, ejecutar las funciones que el atacante desee.

Si bien los ataques de inyección de código son extremadamente comunes, también lo son las defensas disponibles que se pueden usar para detenerlos. En este episodio, aprenderemos lo siguiente:

  • Cómo funcionan
  • Por qué son tan peligrosos
  • Cómo puedes establecer defensas para detenerlos.

¿Cómo utilizan los atacantes la inyección de código?

Si bien los detalles específicos sobre los ataques de inyección de código cambian según el lenguaje de programación utilizado, cualquier aplicación o sitio web puede ser vulnerable siempre que permita al usuario introducir datos. Se han activado ataques de inyección de código para SQL, HTML, XML, CSS y cualquier otro lenguaje de programación común.

En primer lugar, un atacante debe localizar el código vulnerable dentro de una aplicación, normalmente en un punto en el que los usuarios pueden introducir sus propios datos. Por ejemplo, este código toma la función eval () de PHP y la pasa a un usuario para que la modifique, sin ningún tipo de validación de la cadena devuelta.

$myvar = «varname»;
$x = $_GET [argumento];
eval («\ $myvar =\ $x;»);

Un atacante inteligente podría añadir fácilmente su propia cadena a la función eval e incluso ejecutar comandos del sistema si así lo desea.

/index.php? arg=1; sistema (id)

Es importante tener en cuenta que, si bien los ataques de inyección de código pueden implicar el envío de comandos del sistema, no se limitan a hacerlo. De hecho, en los ataques de inyección de código, los piratas informáticos solo están limitados por la funcionalidad del lenguaje en sí. En nuestro ejemplo, un atacante podría programar el sistema objetivo para que hiciera casi cualquier cosa permitida por el marco PHP.

¿Por qué son tan peligrosos los ataques de inyección de código?

Los ataques de inyección de código son potencialmente extremadamente peligrosos según la habilidad del atacante. Pueden hacer cualquier cosa que el lenguaje de programación les permita, lo que los coloca en pie de igualdad con los programadores de la aplicación. Un atacante podría prácticamente escribir su propia aplicación y hacer que se ejecute en el entorno objetivo.

Incluso los atacantes menos hábiles pueden ser peligrosos. En lugar de escribir su propia aplicación o cadenas de código, pueden simplemente ordenar al sistema objetivo que acepte e instale malware preprogramado. Esto podría provocar la desfiguración del sitio, ataques de ransomware o incluso convertirse en la base de una campaña de suplantación de identidad dirigida contra los usuarios del sitio.

La mayoría de las veces, los ataques de inyección de código se utilizan para robar cosas como listas de usuarios y contraseñas, o para obtener un valioso reconocimiento de un sistema que se ve amenazado aún más. Sin embargo, ten en cuenta que un programador experto puede hacer casi cualquier cosa ante un ataque de inyección de código, por lo que es fundamental que se descubran todos los posibles casos en los que se produzca y se eliminen del entorno.

¡No confíes en nadie! (O al menos, no los usuarios)

Al eliminar las vulnerabilidades de los ataques de inyección de código, lo primero que hay que buscar es cualquier lugar que solicite o permita la entrada del usuario. No se puede confiar en nada que introduzca un usuario bajo ninguna circunstancia. Si permites la entrada de los usuarios sin filtrar ni examinar, básicamente estás invitando a los atacantes a que intenten poner en peligro tu sistema o incluso tu red.

Aunque no siempre es posible, la mejor manera de frustrar los ataques de inyección de código es impedir que las funciones ejecuten o interpreten directamente las entradas del usuario. Es posible que los usuarios puedan elegir entre opciones estáticas en lugar de tener libertad para introducir sus propias consultas, programando la aplicación para que solo acepte esas opciones limitadas como válidas. Puede que no siempre sea apropiado hacerlo, pero usarlo siempre que sea posible puede eliminar las inyecciones de código antes de que comiencen.

En las áreas en las que los usuarios deben introducir sus propias entradas, se deben aplicar controles estrictos a esos datos. Asumir que todo es un posible ataque es un buen punto de partida. La aplicación de políticas de privilegios mínimos, como el acceso de usuario de solo lectura, tanto en el lado del cliente como del servidor, puede impedir la ejecución de la mayor parte del código.

La otra buena defensa es implementar filtros en toda la aplicación y desinfectar todo lo que introduzca el usuario. Los desarrolladores conocen los ataques por inyección de código desde hace años, y existen bibliotecas de filtros comprobados para cada marco y lenguaje. Cuando apliques esos filtros, asegúrate de hacerlo no solo en las áreas de entrada obvias de los usuarios o en función de parámetros comunes, como los comandos Get y Post, sino también en función de las cookies y los encabezados HTTP.

Aplicación de una corrección para la inyección de código

Eliminar las áreas de entrada de usuario innecesarias de su entorno, aplicar los principios de mínimo privilegio y utilizar las herramientas de filtrado y desinfección más recientes para inspeccionar y detectar posibles ataques puede cerrar la puerta a esta peligrosa vulnerabilidad. Tener la mentalidad de no confiar nunca en las opiniones de los usuarios también le servirá de mucho para seguir adelante. Haz todo eso y podrás ir un paso por delante de este peligroso tipo de ataque.

Para leer más, puede echar un vistazo al OWASP artículo sobre inyección de código. También puedes poner a prueba tus nuevos conocimientos defensivos con el demo gratuita de la plataforma Secure Code Warrior, que forma a los equipos de ciberseguridad para que se conviertan en los mejores ciberguerreros. Para obtener más información sobre cómo derrotar esta vulnerabilidad y la galería de otras amenazas de los delincuentes, visita la Blog de Secure Code Warrior.

Inyección frontal de código, ahora mismo. Acepta el desafío en nuestra plataforma de formación gamificada: [Empieza aquí]

目录

下载PDF
查看资源
感兴趣了解更多吗?

Jaap Karan Singh是一位安全编码布道者,首席辛格和Secure Code Warrior 的共同创始人。

了解更多

Secure Code Warrior 您的组织在软件开发全生命周期中保护代码安全,并营造将网络安全置于首位的企业文化。无论您是应用安全管理员、开发人员、首席信息安全官,还是任何与安全相关的工作人员,我们都能助力您的组织降低不安全代码带来的风险。

预约演示下载
分享到:
领英品牌社交x 标志
资源中心

入门资源

更多出版物
资源中心

入门资源

更多出版物