关于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 : curl fsockopen 去访问站点时候,相应时间特别长
  • 如何在数据库里优化 汉明距离 查询?
  • 关于php框架ci的性能
  • 本地 Homestead 配置laravel环境 使用域名访问报错
  • wordpress 的文章中能嵌入 php 代码么?
  • 子函数被调用后没有页面输出
  • 关于PHP 变量或非变量 及5和7版本之间 运算符的一些疑问 ?
  • 请教一条mysql的sql语句写法;
  • 区域内匹配的正则表达式应该怎么写?
  • mysql触发器怎么编写?