I am currently using legacy code to get data from users:
$lastName = $_POST['lastName'];
$firstName = $_POST['firstName'];
$examLevel=$_POST['level'];
$dbc=mysql_connect("localhost", "user", "passw") or die('Error connecting to MySQL server');
mysql_select_db("db") or die('Error selecting database.');
$lastName=mysql_real_escape_string($lastName);
$firstName=mysql_real_escape_string($firstName);
$examLevel=mysql_real_escape_string($examLevel);
$query_personal = "INSERT INTO personal (LastName, FirstName) VALUES ('$lastName', '$firstName')";
$query_exam = "INSERT INTO exam (Level, Centre, BackupCentre, etc.) VALUES ('$examLevel', '$centre', '$backup', 'etc')";
This works, but I continue to run into security warnings and a lack of support. There's a little rewrite of connect with mysqli instead of mysql, but what about mysqli_real_escape_string ? I saw how this was used in the examples, but I also saw tips for using ready-made statements instead that don't use mysqli_real_escape_string.
And how can I use prepared instructions for inserting my data? I am still a little at sea. For example, parameter binding only for INSERT and result binding only for SELECT?
source
share