请教下大神,使用了 pdo 是不是就可以无视 sql 注入了? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
peizhao2017
V2EX    问与答

请教下大神,使用了 pdo 是不是就可以无视 sql 注入了?

  •  
  •   peizhao2017 2018-06-03 19:05:48 +08:00 2803 次点击
    这是一个创建于 2769 天前的主题,其中的信息可能已经有所发展或是发生改变。
    请教下大神
    使用了 pdo 是不是就可以无视 sql 注入了?

    努力了一下午
    用 medoo 把网站原来的 mysqli 拼接语句换成 pdo

    那么现在问题来了
    在不考虑极端情况下
    pdo 可以不过滤任何用户输入的内容直接入库吗?
    11 条回复    2018-06-03 21:38:05 +08:00
    carlclone
        1
    carlclone  
       2018-06-03 19:08:08 +08:00 via Android
    prepare 预处理查询语句
    m939594960
        2
    m939594960  
       2018-06-03 19:34:45 +08:00
    只要用参数绑定的话可以。很多框架应该都是这么做的。 当然不排除将来有其他绕过的方法
    hly9469
        3
    hly9469  
       2018-06-03 19:35:52 +08:00 via iPhone
    pdo 只是个数据库连接驱动,跟防注入有啥关系?
    hly9469
        4
    hly9469  
       2018-06-03 19:36:25 +08:00 via iPhone
    @hly9469 #3 还得靠参数绑定之类的
    Felldeadbird
        5
    Felldeadbird  
       2018-06-03 19:43:51 +08:00 via iPhone
    mysqli 也可以参数绑定。这个是将提交参数给数据库处理。这样才可以防止注入。
    当然,以后出来 bug 一样会有注入。只是现在还没出现
    peizhao2017
        6
    peizhao2017  
    OP
       2018-06-03 19:50:55 +08:00
    @Felldeadbird #5

    我话没说全

    我想问的是

    原来用的是 sql 拼接

    现在改成了 PDO::prepare


    那么在 PDO::prepare 的情况下

    还需要对用户的输入内容做各种转义和过滤吗??

    是不是就可以直接入库
    SourceMan
        7
    SourceMan  
       2018-06-03 20:10:53 +08:00 via iPhone
    大部分情况可以
    Death
        8
    Death  
       2018-06-03 20:15:14 +08:00 via Android
    hilow
        9
    hilow  
       2018-06-03 20:16:31 +08:00
    经过 prepare 后的参数,对 mysql 来说,是安全的,可以直接入库
    但安全是个大问题,对 mysql 安全的数据,也许在其他地方使用,就会引起注入问题
    比如 存入 mysql 中的是 js 代码,那你经过处理直接把这些 文本 用到前端,就可能引起问题
    推荐一本书 白帽子讲 web 安全,里面有全面的有关示例
    peizhao2017
        10
    peizhao2017  
    OP
       2018-06-03 21:32:21 +08:00
    @Death #8
    小站
    先不考虑这种二阶注入

    本来也没有绝对的安全的方法
    peizhao2017
        11
    peizhao2017  
    OP
       2018-06-03 21:38:05 +08:00
    @hilow #9



    如果不过滤和转义的内容 PDO::prepare 后对 MySQL 是安全的

    那么 xss 方面我用白名单

    即前端输出的时候只留常规的<p><br><img>等需要的 html 标签

    其他的一律过滤不显示或转义后显示

    这样是不是就基本可以预防大部分的 sql 注入和 xss 攻击了
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     953 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 18:16 PVG 02:16 LAX 10:16 JFK 13:16
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86