[转载]PHP中防止SQL注入式攻击

更新:2018年07月06日 13:17 PHP 阅读(0)
标签: @PHP @SQL注入 #作者: 未知
SQL注入攻击是黑客攻击网站最常用的手段。如果你的站点没有使用严格的用户输入检验,那么常容易遭到SQL注入攻击。SQL注入攻击通常通过给站点数据库提交不良的数据或查询语句来实现,很可能使数据库中的纪录遭到暴露,更改或被删除。下面来谈谈SQL注入攻击是如何实现的,又如何防范。

本文我们来继续学习,php防SQL注入式攻击。


一、注入式攻击的类型
  可能存在许多不同类型的攻击动机,但是乍看上去,似乎存在更多的类型。这是非常真实的-如果恶意用户发现了一个能够执行多个查询的办法的话。本文后面,我们会对此作详细讨论。


  如果你的脚本正在执行一个SELECT指令,那么,攻击者可以强迫显示一个表格中的每一行记录-通过把一个例如"1=1"这样的条件注入到WHERE子句中,如下所示(其中,注入部分以粗体显示):


SELECT * FROM wines WHERE variety = 'lagrein' OR 1=1;'


  正如我们在前面所讨论的,这本身可能是很有用的信息,因为它揭示了该表格的一般结构(这是一条普通的记录所不能实现的),以及潜在地显示包含机密信息的记录。


  一条更新指令潜在地具有更直接的威胁。通过把其它属性放到SET子句中,一名攻击者可以修改当前被更新的记录中的任何字段,例如下面的例子(其中,注入部分以粗体显示):


UPDATE wines SET type='red','vintage'='9999' WHERE variety = 'lagrein'
  通过把一个例如1=1这样的恒真条件添加到一条更新指令的WHERE子句中,这种修改范围可以扩展到每一条记录,例如下面的例子(其中,注入部分以粗体显示):


UPDATE wines SET type='red','vintage'='9999 WHERE variety = 'lagrein' OR 1=1;'


  最危险的指令可能是DELETE-这是不难想像的。其注入技术与我们已经看到的相同-通过修改WHERE子句来扩展受影响的记录的范围,例如下面的例子(其中,注入部分以粗体显示):
DELETE FROM wines WHERE variety = 'lagrein' OR 1=1;'


二、多个查询注入


  多个查询注入将会加剧一个攻击者可能引起的潜在的损坏-通过允许多条破坏性指令包括在一个查询中。在使用MySQL数据库时,攻击者通过把一个出乎意料之外的终止符插入到查询中即可很容易实现这一点-此时一个注入的引号(单引号或双引号)标记期望变量的结尾;然后使用一个分号终止该指令。现在,一个另外的攻击指令可能被添加到现在终止的原始指令的结尾。

感谢阅读本文,若本文对你有所帮助,不妨将其推荐给好友,与好友一起分享。
文章仅做学习交流使用,若您认为文章存在侵权或不合法行为等,请及时联系我们。
文章之版权归其合法拥者所有。转载原创内容无需联系本站站长,请注明原文出处及链接。
#原文:[IT技术网] http://www.173it.cn/view-375-1.html
更新:2018年07月06日 13:17 PHP 阅读(0)
标签: @PHP @SQL注入 #作者: 未知

阅读延伸

CentOS7系统安装Redis5.0.5并安装PHP-redis扩展 | 暮云归

VM虚拟机,CentOS7系统,已安装完整的LAMP。PHP版本为7.3.25(PHP7+)。
现在的目的是为该系统安装Redis服务(Redis5.0.5),该版本在当下是比较新的稳定版。
还有就是为我们的PHP安装redis扩展(可通过phpinfo()函数看到redis扩展的具体信息)

[原创]Centos7系统为php7安装memcache扩展 | 十年铸剑

这篇文章主要记录本人安装的历程,若有需要,希望能对大家起到一点作用,哈哈。
这是在虚拟机中安装memcache扩展,虚拟机安装的系统是CentOS7,已正常安装了PHP7.3.25.

[转载]Mysql 工作原理 | Still water run deep

刚开始接触一个新的事物的时候,我觉得很有必要从其工作原理入手。
弄清楚这个东西的来龙去脉,为接下来的继续深入学习做好铺垫。
掌握好其原理有助于我们从整体上来把握这个东西,并且帮助我们在排错过程中理清思路。

[原创]ThinkPHP3.1快速入门 多语言 | 十年铸剑

ThinkPHP支持多语言,采用的是语言文件的方式。
如果你的应用涉及到多个语言版本和国际化的支持,那么可以定义相关的语言包文件。任何字符串形式的输出,都可以定义语言常量。

[原创]PHPCMS 调用自定义幻灯片广告 | 十年铸剑

phpcms的广告位管理功能非常强大,一般情况下调用广告位只需要引进一个js文件就可以了,但若要实现点击切换的广告位(幻灯片广告,或者叫做轮播广告)就有些困难(主要是默认没有切换的滑动点,或滑动点的样式不能自定义),于是就不能直接应用phpcms给出的引用js文件的方式来实现了。
标签: @PHPCMS @幻灯片 PHP 十年铸剑 05月02日 20:05 继续阅读

[转载]php对文件的操作

创立文件夹
循环建立文件夹
检测文件类型
上传文件
标签: @PHP @文件 @文件夹 PHP 未知 05月02日 20:05 继续阅读

[转载]php通过正则表达式匹配url

php通过正则表达式匹配url
标签: @PHP @正则 @匹配URL PHP 未知 05月02日 20:05 继续阅读

[转载]Linux环境下如何使用PHP处理图像

利用PHP创建图像是相当容易的一件事情。只要安装一些第三方的库文件并具有一定的几何知识,就可以利用PHP来创建和处理图像了。目前PHP使用GD库处理图像。在PHP中一些图像函数是可以直接使用的,但是大多数函数需要安装GD函数库。GD库提供一系列函数进行画图、使用颜色、处理预存的图像和填充操作。GD库是ThomasBoutell设计的ANSIC语言编写,同时支持在perl、Tcl语言中作图。由于GD是一个可以被建立成共享或静态的库,所以在PHP使用GD库进行图像操作是非常容易的。
标签: @Linux @PHP @处理图像 PHP 未知 05月02日 20:05 继续阅读

[转载]Linux环境下如何使用PHP处理图像(4)

利用PHP创建图像是相当容易的一件事情。只要安装一些第三方的库文件并具有一定的几何知识,就可以利用PHP来创建和处理图像了。目前PHP使用GD库处理图像。在PHP中一些图像函数是可以直接使用的,但是大多数函数需要安装GD函数库。GD库提供一系列函数进行画图、使用颜色、处理预存的图像和填充操作。GD库是ThomasBoutell设计的ANSIC语言编写,同时支持在perl、Tcl语言中作图。由于GD是一个可以被建立成共享或静态的库,所以在PHP使用GD库进行图像操作是非常容易的。
标签: @Linux @PHP @处理图像 PHP 未知 05月02日 20:05 继续阅读

[转载]Php部分常见问题总结(1) | hdm58

1:为什么我得不到变量
我在一网页向另一网页POST数据name,为什么输出$name时却得不到任何值?在PHP4.2以后的版本中register_global默认为off若想取得从另一页面提交的变量:
方法一:在PHP.ini中找到register_global,并把它设置为on.
方法二:在接收网页最前面放上这个extract($_POST);extract($_GET);(注意extract($_SESSION)前必须要有Session_Start()).
方法三:一个一个读取变量$a=$_GET["a"];$b=$_POST["b"]等,这种方法虽然麻烦,但比较安全.
标签: @PHP @常见问题 PHP hdm58 05月02日 20:05 继续阅读