From: prikid at gmail dot com Operating system: FreeBSD 6 PHP version: 5.2.4 PHP Bug Type: JSON related Bug description: json_encode does not escape single quotes
Description: ------------ When using json_encode() and trying to insert into mysql table field with single quotes - single quote is not escaped and mysql produces error. Reproduce code: --------------- $name = "Mike O'Brien"; $email = "[EMAIL PROTECTED]"; $settings = array("name"=> $name,"email" => $email); $json = json_encode($settings); $sql = "INSERT INTO `users` VALUES('".$json."')"; $result = mysql_query($sql) or die (mysql_error()); Expected result: ---------------- Successfull mysql insertion with escaped single quote. Actual result: -------------- You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'Brien -- Edit bug report at http://bugs.php.net/?id=42569&edit=1 -- Try a CVS snapshot (PHP 4.4): http://bugs.php.net/fix.php?id=42569&r=trysnapshot44 Try a CVS snapshot (PHP 5.2): http://bugs.php.net/fix.php?id=42569&r=trysnapshot52 Try a CVS snapshot (PHP 6.0): http://bugs.php.net/fix.php?id=42569&r=trysnapshot60 Fixed in CVS: http://bugs.php.net/fix.php?id=42569&r=fixedcvs Fixed in release: http://bugs.php.net/fix.php?id=42569&r=alreadyfixed Need backtrace: http://bugs.php.net/fix.php?id=42569&r=needtrace Need Reproduce Script: http://bugs.php.net/fix.php?id=42569&r=needscript Try newer version: http://bugs.php.net/fix.php?id=42569&r=oldversion Not developer issue: http://bugs.php.net/fix.php?id=42569&r=support Expected behavior: http://bugs.php.net/fix.php?id=42569&r=notwrong Not enough info: http://bugs.php.net/fix.php?id=42569&r=notenoughinfo Submitted twice: http://bugs.php.net/fix.php?id=42569&r=submittedtwice register_globals: http://bugs.php.net/fix.php?id=42569&r=globals PHP 3 support discontinued: http://bugs.php.net/fix.php?id=42569&r=php3 Daylight Savings: http://bugs.php.net/fix.php?id=42569&r=dst IIS Stability: http://bugs.php.net/fix.php?id=42569&r=isapi Install GNU Sed: http://bugs.php.net/fix.php?id=42569&r=gnused Floating point limitations: http://bugs.php.net/fix.php?id=42569&r=float No Zend Extensions: http://bugs.php.net/fix.php?id=42569&r=nozend MySQL Configuration Error: http://bugs.php.net/fix.php?id=42569&r=mysqlcfg