Un API es un contrato entre un autor de llamada y un receptor de llamada. Las formas de abuso de API más comunes los produce el autor de llamada cuando no consigue atender su fin de este contrato. Por ejemplo, si un programa no consigue llamar chdir() después de llamar chroot(), se viola el contrato que especifica cómo cambiar el directorio de origen activo de una forma segura. Otro buen ejemplo de un abuso de manual es esperar que el receptor devuelva una información de DNS de confianza al autor de llamada. En este caso, el autor de llamada abusa el API del receptor haciendo determinadas suposiciones sobre su comportamiento (que el valor de retorno se puede usar con fines de autenticación). También se puede violar el contrato entre el autor de llamada y el receptor desde el otro lado. Por ejemplo, si un codificador envía SecureRandom y devuelve un valor no aleatorio, se viola el contrato.
Dangerous Function: Unsafe Regular Expression
Ejemplo 1: dada la URL
http://www.example.com/index.php?param=...
, el siguiente fragmento de código de php dentro de index.php
imprimirá el valor del parámetro de URL param
(transferido en lugar de "...") en la pantalla si coincide con la expresión regular de POSIX '^[[:alnum:]]*$'
que representa a "cero o más caracteres alfanuméricos":
<?php
$pattern = '^[[:alnum:]]*$';
$string = $_GET['param'];
if (ereg($pattern, $string)) {
echo($string);
}
?>
Mientras que el
Example 1
funciona como se esperaba con la entrada alfanumérica, debido a que se utiliza la función ereg()
no segura para validar la entrada contaminada, es posible llevar a cabo un ataque de scripts de sitios (XSS) mediante la inyección de un byte null
. Al pasar un valor para param
que contiene una cadena alfanumérica válida seguida de un byte null
y, a continuación, una etiqueta <script>
(por ejemplo, "Hello123%00<script>alert("XSS")</script>"
), ereg($pattern, $string)
seguirá siendo true
, dado que la función ereg()
ignora todo lo que sigue a un carácter de byte null
al leer la cadena de entrada (de izquierda a derecha). En este ejemplo, esto significa que la etiqueta <script>
inyectada seguida del byte null
se mostrará al usuario y se evaluará.