[PHP] sql injection 防御 関数, mysql_real_escape_string
PHP 公式 ハングル 説明 : mysql_real_escape_string
SQL インジェクション 攻撃は ID私 PASSWORD イブリョックカンに SQL門を 入れて DBを はたく のを 言う.
PHP 公式 ウェブサイトには SQL インジェクション 攻撃の 例で 下と ような のを 入って おいて ある.
// ユーザーが あるのか DBで チェックする クイーリー $query = "SELECT * FROM users WHERE user='{$_POST['username']}' AND password='{$_POST['password']}'"; mysql_query($query); // $_POST['password']を チェックする 数 なく なって, どうな ユーザーでも 許容するように なる. 例を 入れば: $_POST['username'] = 'aidan'; $_POST['password'] = "' OR ''='"; // MySQLに こういう クイーリーが 送信されるという のを 意味する: echo $query; //SELECT * FROM users WHERE user='aidan' AND password='' OR ''=''
mysql_real_escape_string 関数は ところで こういう 攻撃を 阻んで 与える 関数だ.
PHP 公式 ウェブサイトには 下を 模範 例題で 入って ある.
if (isset($_POST['product_name']) && isset($_POST['product_description']) && isset($_POST['user_id'])) { // 接続 $link = mysql_connect('mysql_host', 'mysql_user', 'mysql_password'); if(!is_resource($link)) { echo "サーバー 接続 失敗n"; // ... 間違いを 適切に 記録 } else { // ON仕事 場合 magic_quotes_gpc/magic_quotes_sybase 效果 除去 if(get_magic_quotes_gpc()) { $product_name = stripslashes($_POST['product_name']); $product_description = stripslashes($_POST['product_description']); } else { $product_name = $_POST['product_name']; $product_description = $_POST['product_description']; } // 安全な 質の 作り $query = sprintf("INSERT INTO products (`name`, `description`, `user_id`) VALUES ('%s', '%s', %d)", mysql_real_escape_string($product_name, $link), mysql_real_escape_string($product_description, $link), $_POST['user_id']); mysql_query($query, $link); if (mysql_affected_rows($link) > 0) { echo "Product insertedn"; } } } else { echo "Fill the form propertyn"; }
上と ような 方式で 使えば なる.
- コメント機能はありません。コメントの代わりに[email protected]
にメールを送ってください。