php - mysql注入问题
PHPz
PHPz 2017-04-10 13:10:31
0
8
731

AND (SELECT 2693 FROM(SELECT COUNT(*),:vxd:,(SELECT MID((IFNULL(CAST(count(*) AS CHAR),'')),1,50) FROM vip_card WHERE sn like '20%' and active=1),:hez:,0)x FROM information_schema.tables GROUP BY x)a)

以上是我查到被注入的语句,请问这条语句是如何产生的,网站又需要如何更好地去防御这类攻击?

PHPz
PHPz

学习是最好的投资!

모든 응답(8)
数据分析师

php - mysql 주입 문제 - PHP 중국어 웹사이트 Q&A - php - mysql 주입 문제 - PHP 중국어 웹사이트 Q&A

둘러보고 배워보세요.

刘奇

此处原本代码应该当是and(后跟的变量未被过滤,从代码来看,此处应当期望输入的是一个数字,所以此处应当intval输入的参数。

例如

$sql = "SELECT xxx from table where cid = '1' and (".intval($_GET['ids'].")";

我之所以认为这边期望输入的是一个数字,是因为and后面的(内没有单引号,不是and(',如果期望引用的不是数字而是字符串的话,在正常业务中就会出错。

我建议,引用输入的时候,都必须用单引号包裹,可以考虑楼上说的pdo这类占位符机制引入变量

您可以看看pdo中的prepare。:)

PHPzhong

mysql 和 php 都提供了放注入的机制。不过,推荐使用 PDO。

阿神

传入参数要用参数对象来处理。自己直接=号,很容易被注入。

洪涛

防注入~~我选PDO。。。

黄舟

PDO.... 同意楼上的

迷茫

PDO修炼中

刘奇

稍大一点的公司都会封装一些函数来防注入的....

최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!