In the process of transitioning from mysql_* to PDO, you may encounter a dilemma with the absence of a direct equivalent to mysql_real_escape_string.
No Direct Equivalent
Technically, there is PDO::quote(), but its usage is limited. The true solution lies in the correct implementation of prepared statements.
Prepared Statements Protect against Injections
PDO, when used with prepared statements, inherently protects against MySQL injections without the need for additional escaping. Prepared statements bind input parameters to placeholders, preventing malicious input from being interpreted as SQL commands.
Example: Using Prepared Statements in PDO
The following code demonstrates a secure database query using prepared statements:
<code class="php"><?php $db = new \PDO("mysql:host=localhost;dbname=xxx;charset=utf8", "xxx", "xxx", [ PDO::ATTR_EMULATE_PREPARES => false, PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION ]); if ($_POST && isset($_POST['color'])) { $stmt = $db->prepare("SELECT id, name, color FROM Cars WHERE color = ?"); $stmt->execute(array($_POST['color'])); $cars = $stmt->fetchAll(\PDO::FETCH_ASSOC); var_dump($cars); } ?></code>
Benefits of Prepared Statements
Additional Considerations
Conclusion
Prepared statements in PDO provide a robust and secure mechanism for database queries without the need for functions like mysql_real_escape_string. By embracing this approach, you can effectively prevent SQL injections and maintain the integrity of your data.
The above is the detailed content of How to Replace mysql_real_escape_string in PDO: Prepared Statements as the Solution?. For more information, please follow other related articles on the PHP Chinese website!