php pdo 传参,关于pdo引用传参,字段是不是不能当成参数传入?

本文探讨了使用PDO进行SQL参数绑定时出现的问题,包括为何某些情况下无法正确获取数据及如何避免SQL注入攻击。通过实例说明了正确的参数绑定方式。

$pdo= new PDO ( 'mysql:host=localhost;dbname=test;', 'root', '123456', array (PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES 'utf8'",PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION) );$stmt=$pdo->prepare('select ? from tianya_post where id=1');$stmt->bindValue(1, 'title');$stmt->execute();print_r($stmt->fetch());

第一行记录的标题是:“我和嫂子的那些事儿”

但,列位看官,猜下结果是什么?

Array

(

[title] => title

[0] => title

)

为什么会这样?

如果用

select title from tianya_post where id=?

$stmt->bindValue(1, 1);

可以得到正确的标题的。

回复讨论(解决方案)

字段列表不是参数!

http://blog.csdn.net/fdipzone/article/details/22330345

需要注意的是以下几种情况,PDO并不能帮助你防范SQL注入。

不能让占位符 ? 代替一组值,这样只会获取到这组数据的第一个值,如:

select * from table where userid in ( ? );

如果要用in?查找,可以改用find_in_set()实现

$ids = '1,2,3,4,5,6';

select * from table where find_in_set(userid, ?);

不能让占位符代替数据表名或列名,如:

select * from table order by ?;

不能让占位符 ? 代替任何其他SQL语法,如:

select extract( ? from addtime) as mytime from table;

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值