防止sql注入的最好方法决不是自己组装sql命令和参数,而是使用pdo的prepare和bind。其原理是将sql查询命令与传递的参数分开:>准备时,dbserver会将sql语句解析为sql命令。>绑定时,它只会动态地将参数传递给db所有其他过滤特殊字符串的方法,如白名单,都是浮云。
谢谢您的邀请。对于你的问题,我有以下答案,希望能解决你的困惑。
首先回答第一个问题:什么是sql注入?
一般来说,黑客在网站表单中插入恶意sql语句,提交或输入域名请求查询语句,最后欺骗网站服务器执行恶意sql语句。通过这些sql语句,黑客可以获得一些他们想要的数据信息和用户信息,也就是说,如果有sql注入,那么他们就可以执行sql语句的所有命令
让我扩展一个问题:sql注入的原因是什么?
数据库属于网站代码没有严格分离,当黑客提交的参数数据没有得到充分的检查和防御时,黑客就会输入恶意sql命令,改变原来的sql命令语义,将黑客执行的语句放入数据库中执行。
现在回答第二个问题:我们常用的注射方法是什么?
我们常用的提交方法是get和post
首先,get,get提交方法。例如,如果要查询数据,则查询代码将显示在链接中。您可以看到我们的id=1,1是我们搜索的内容。当链接出现时,这是get。
第二个是postsubmission方法是不可见的。我们需要用工具来观察它。我们需要使用hackbar浏览器插件
以这种方式提交。我在这里搜索了2,显示的数据不同。这是数据库的查询功能。在这种情况下,get提交比post提交更有害。
第二个是postsubmission方法是不可见的。我们需要用工具来观察它。我们需要使用hackbar浏览器插件。
这就是我的答案。我希望它能帮助你。