php

Sentencias preparadas con MySQLi y PHP

En este post te explicaré cómo usar sentencias preparadas o prepared statements en PHP al usar la extensión MySQLi para evitar inyecciones SQL y especificar los parámetros.

Vamos a ver cómo usar bind_param y execute.

¿Por qué usar sentencias preparadas?

Siempre hay que tener varias capas de seguridad. Una de ellas debe ser la de prevenir inyecciones SQL. Las sentencias preparadas sirven justamente para eso.

Crear una sentencia

Una vez que tenemos a la conexión de MySQLi invocamos a prepare pasándole la consulta. Por ejemplo:

See the gist on github.

En este caso ya tenemos un prepared statement. Ahora es momento de invocar a bind_param, pero antes de eso fíjate en que en lugar de pasar directamente los valores concatenando cadenas, los indicamos con signos de interrogación ?.

Explicación de bind_param

Esta función recibe el tipo de dato del parámetro, en el orden en el que aparece dentro de la consulta. Y después recibe los verdaderos valores.

Los tipos de datos son s para cadena, i para entero, d para doble (contempla el tipo de dato decimal) y b para blob. Si son varios parámetros, pasamos los caracteres en la misma cadena.

En este caso para el ejemplo solo tenemos dos valores que son de tipo string así que la cadena es ss y después pasamos los dos valores.

See the gist on github.

Finalmente invocamos a execute para ejecutar la sentencia y de este modo se hará la inserción pero evitando inyecciones SQL.

Poniendo todo junto

Solo para terminar el post, colocaré el código de referencia:

See the gist on github.

 

Encantado de ayudarte


Estoy disponible para trabajar en tu proyecto, modificar el programa del post o realizar tu tarea pendiente, no dudes en ponerte en contacto conmigo.

No te pierdas ninguno de mis posts

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

Entradas recientes

Monitorear cola de impresión en Windows

En este artículo te voy a enseñar a monitorear la cola de impresión de una…

5 horas hace

Solución: Unable to extract uploader id con youtube-dl

En mi blog te he enseñado a usar youtube-dl para descargar vídeos con permiso del…

4 días hace

Enviar foto a Telegram usando cURL y Bot

Siguiendo con los tutoriales que consumen la API de los Bots de Telegram con cURL…

4 días hace

cURL y Telegram: enviar mensaje a Bot

En un post previo te enseñé a enviar un mensaje en nombre de un Bot…

4 días hace

Impresora térmica con Telegram usando Bot

En este artículo te voy a mostrar una guía para imprimir en una impresora térmica…

4 días hace

Imprimir PDF con Bot de Telegram

La impresión de un PDF en cualquier impresora se puede automatizar con un bot de…

1 semana hace

Esta web usa cookies.