关于php函数addslashes的一些小疑问

我把用户通过post发过来的数据”my’name”通过addslashes函数进行过滤,然后存入mysql
但是当我在php脚本页面执行
$conn = new mysqli(‘127.0.0.1′,’root’,”,’book_sc’);
$re = $conn->query(“select * from sc where title='”.”my’name”.”‘”);
var_dump($re->num_rows); //返回是NULL

但是在mysql里执行命令
mysql> select * from sc where title=”my’name”;
或者
mysql> select * from sc where title=”my\’name”;
都可以查询到这条数据,那为什么在php脚本页面执行就返回null呢?
还有就是过滤的函数还有strip_tags、htmlspespecialchars分别用于过滤掉html、php代码和转义html代码以保证数据的安全性,那我是不是需要把这3个函数都用上?

我很奇怪你执行 $re = $conn->query("select * from sc where title='"."my'name"."'");
怎么没有报错? 很明显这sql就有错误。
应该这样 $conn->query("select * from sc where title='my\'name'")

  • PHP的信息安全(入侵获取$flag)的题目【Q2】
  • 求搜狐微博php sdk还有豆瓣的!
  • 关于在服务端(PHP)调用V8进行页面渲染的疑惑
  • submail群发邮件疑问
  • 客户端上报数据到数据库,怎么才能不被抓包到上传的内容和数据库信息
  • 如何做到在PHP脚本超时之前就结束脚本的执行
  • YII2邮件配置,网上方法不凑效!
  • 业务逻辑放在controller层好还是model层好
  • 上传文件出现 413错误
  • CURL POST数据量过大,接收不到服务端的信息
  • 移动开发 点击某个按钮弹出个input 会产生滚动 怎么禁止滚动条呢??