ホームページ  >  記事  >  バックエンド開発  >  php pdo プレースホルダーの使用 (コード例で説明)

php pdo プレースホルダーの使用 (コード例で説明)

jacklove
jackloveオリジナル
2018-05-22 17:48:482858ブラウズ

この記事では、php pdo プレースホルダーの使用について説明します。

php pdo プレースホルダーの使用 (コード例の説明)

php pdo の使用

SQL インジェクションを防ぐ

$dbms='mysql';//数据库类型
$host='localhost';//数据库主机名
$dbName='test';//使用的数据库
$user='root';//数据库连接用户名
$pass='root';//对应的密码
$dsn="$dbms:host=$host;dbname=$dbName"; 
try{
$db=newPDO($dsn,$user,$pass);//初始化一个PDO对象
}catch(PDOException$e){
die("Error!:".$e->getMessage()."
");
}
$username=isset($_GET['username'])?$_GET['username']:'';
$ip=isset($_GET['ip'])?$_GET['ip']:'';
$mac=isset($_GET['mac'])?$_GET['mac']:'';
$apMac=isset($_GET['apMac'])?$_GET['apMac']:'';
$loginTime=isset($_GET['loginTime'])?$_GET['loginTime']:'';
$time=date('Y-m-dH:i:s');
 
//编写sql使用占位符
$sql="insertintotest(username,ip,mac,apMac,loginTime,insert_time)
values(:username,:ip,:mac,:apMac,:loginTime,'$time')";
$query=$db->prepare($sql);
/**
感觉挺麻烦的
$query->bindParam(':username',$username);
$query->bindParam(':ip',$ip);
$query->bindParam(':mac',$mac);
$query->bindParam(':apMac',$apMac);
$query->bindParam(':loginTime',$loginTime);
$query->execute();
**/
$result=$query->execute(array(
    ':username'=>$username,
    ':ip'=>$ip,
    ':mac'=>$mac,
    ':apMac'=>$apMac,
    ':loginTime'=>$loginTime,
));

この記事では、php pdo プレースホルダーの使用について説明します。関連コンテンツの詳細については、php 中国語の Web サイトを参照してください。

関連する推奨事項:

PHP はバケット ソート アルゴリズムを実装します

PHP ソート アルゴリズム シリーズのマージ ソートの詳細な説明

thinkPHP5 フレームワーク データベースのコヒーレント操作:cache() の使用方法の詳細

以上がphp pdo プレースホルダーの使用 (コード例で説明)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。