I just discovered this, I use MySQL as my database.
When i do something like:
$query = $this->db->where('id', '6rubbish')->get('posts', 1);
it generates and executes this SQL:
SELECT *
FROM (`posts`)
WHERE `id` = '6rubbish'
LIMIT 1
The surprising thing is that it actually fetches the post with the ID 6.
I find this very vulnerable in same cases because i’m trying to exactly match the ID, not to do a LIKE query.
Any ideas?
Yes.
But the origin of the problem is that your query generator library doesn’t understand the variable types, PHP being a dynamic typed language doesn’t help too.
I don’t know what library you’re using, maybe there is an option to tell that you’re passing an int? It should protect you from SQL injection, I hope, try with:
and see if the generated SQL has the single quoted escaped (doubled or preceded by backslash).