What are some best practices for handling user input to prevent SQL injections in PHP applications?

To prevent SQL injections in PHP applications, it is essential to use prepared statements with parameterized queries when interacting with the database. This approach separates the SQL query logic from the user input data, making it impossible for malicious input to alter the query structure.

// Establish a database connection
$pdo = new PDO('mysql:host=localhost;dbname=mydatabase', 'username', 'password');

// Prepare a SQL statement with a placeholder for user input
$stmt = $pdo->prepare('SELECT * FROM users WHERE username = :username');

// Bind the user input to the prepared statement
$stmt->bindParam(':username', $_POST['username']);

// Execute the statement
$stmt->execute();

// Fetch the results
$results = $stmt->fetchAll();