加入收藏 | 设为首页 | 会员中心 | 我要投稿 北几岛 (https://www.beijidao.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

如何在PHP中处理SQL查询中的单引号?

发布时间:2021-07-06 05:23:30 所属栏目:大数据 来源: https://www.jb51.cc
导读:我正在使用特定的查询来插入记录.一切顺利.我甚至用选择查询获取记录.但我的问题是,如果记录包含单引号”,那么它会给我这个错误: NOTE:You have an error in your sql Syntax; check the manual that corresponds to your MysqL server version for the rig

我正在使用特定的查询来插入记录.一切顺利.我甚至用选择查询获取记录.但我的问题是,如果记录包含单引号”,那么它会给我这个错误:

> NOTE:You have an error in your sql Syntax; 
>     check the manual that corresponds to your MysqL server 
>     version for the right Syntax to use near 'B''' at line 1

SELECT查询是:

$result= MysqL_query("SELECT s.name, 
                             s.sid as sid, 
                             s.category, 
                             p.name as pname 
                         FROM poet p 
                         INNER JOIN song s 
                            ON p.pid = s.pid 
                         WHERE s.name= '$sid'") or die(MysqL_error());

我该怎么做才能跳过引号问题.当我想在我的记录中插入引号时.

解决方法:

你的问题比这更糟糕 – 如果有人输入了价值’; DROP TABLE诗人; – ?您需要使用MysqL_real_escape_string()来转义值,或使用参数化查询(例如,使用PDO).

这是2011年,因为大声哭泣.为什么sql注入仍然是一个普遍的问题?

(编辑:北几岛)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读