您所在位置: 网站首页 / php防止SQL注入的方法分享.docx / 文档详情
php防止SQL注入的方法分享.docx 立即下载
2025-08-18
约2.9千字
约10页
0
13KB
举报 版权申诉
预览加载中,请您耐心等待几秒...

php防止SQL注入的方法分享.docx

php防止SQL注入的方法分享.docx

预览

免费试读已结束,剩余 5 页请下载文档后查看

10 金币

下载文档

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

php防止SQL注入的方法分享

	在php编程中,防范sql注入攻击的简单方法,感兴趣的朋友可以参考下,可能对日常的sql注入防范有一定的帮助。就跟随小编去了解下吧,想了解更多相关信息请持续关注我们应届毕业生考试网!	sql注入产生的原因,一般如下:	一个是没有对输入的数据进行过滤(过滤输入),还有一个是没有对发送到数据库的数据进行转义(转义输出)。	这两个重要的步骤缺一不可,需要同时加以特别关注以减少程序错误。	对于攻击者来说,进行SQL注入攻击需要思考和试验,对数据库方案进行有根有据的推理非常有必要(当然假设攻击者看不到你的源程序和数据库方案)。	例子,一个简单的登录表单:	复制代码代码示例:	<formaction="/login.php"method="POST">	<p>Username:<inputtype="text"name="username"/></p>	<p>Password:<inputtype="password"name="password"/></p>	<p><inputtype="submit"value="LogIn"/></p>	</form>	攻击者会从推测验证用户名和密码的查询语句开始。通过查看源文件,他就能开始猜测你的习惯。	比如命名习惯。通常会假设你表单中的字段名为与数据表中的字段名相同。当然,确保它们不同未必是一个可靠的安全措施。	第一次猜测,一般会使用下面例子中的查询:	复制代码代码示例:	<?php	$password_hash=md5($_POST['password']);	$sql="SELECTcount(*)	FROMusers	WHEREusername='{$_POST['username']}'	ANDpassword='$password_hash'";	?>	使用用户密码的MD5值原来是一个通行的做法,但现在并不是特别安全了。	最近的研究表明MD5算法有缺陷,而且大量MD5数据库降低了MD5反向破解的难度。	请访问http://md5.rednoize.com/查看演示。	最好的保护方法:	在密码上附加一个自定义的字符串,例如:	复制代码代码示例:	<?php	$salt='SHIFLETT';	$password_hash=md5($salt.md5($_POST['password'].$salt));	?>	当然,攻击者未必在第一次就能猜中,他们常常还需要做一些试验。有一个比较好的试验方式是把单引号作为用户名录入,原因是这样可能会暴露一些重要信息。有很多开发人员在Mysql语句执行出错时会调用函数mysql_error()来报告错误。见下面的例子:	复制代码代码示例:	<?php	mysql_query($sql)orexit(mysql_error());	?>	该方法能向攻击者暴露重要信息。如果攻击者把单引号做为用户名,mypass做为密码,查询语句就会变成:	复制代码代码示例:	<?php	$sql="SELECT*	FROMusers	WHEREusername='''	ANDpassword='a029d0df84eb5549c641e04a9ef389e5'";	?>	当该语句发送到MySQL后,系统就会显示如下错误信息:	YouhaveanerrorinyourSQLsyntax.Checkthemanualthatcorrespondstoyour	MySQLserverversionfortherightsyntaxtousenear'WHEREusername='''AND	password='a029d0df84eb55	不费吹灰之力,攻击者已经知道了两个字段名(username和password)以及他们出现在查询中的顺序。除此以外,攻击者还知道了数据没有正确进行过滤(程序没有提示非法用户名)和转义(出现了数据库错误),同时整个WHERE条件的格式也暴露了,这样,攻击者就可以尝试操纵符合查询的记录了。	在这一点上,攻击者有很多选择。一是尝试填入一个特殊的用户名,以使查询无论用户名密
查看更多
单篇购买
VIP会员(1亿+VIP文档免费下)

扫码即表示接受《下载须知》

php防止SQL注入的方法分享

文档大小:13KB

限时特价:扫码查看

• 请登录后再进行扫码购买
• 使用微信/支付宝扫码注册及付费下载,详阅 用户协议 隐私政策
• 如已在其他页面进行付款,请刷新当前页面重试
• 付费购买成功后,此文档可永久免费下载
全场最划算
12个月
199.0
¥360.0
限时特惠
3个月
69.9
¥90.0
新人专享
1个月
19.9
¥30.0
24个月
398.0
¥720.0
6个月会员
139.9
¥180.0

6亿VIP文档任选,共次下载特权。

已优惠

微信/支付宝扫码完成支付,可开具发票

VIP尽享专属权益

VIP文档免费下载

赠送VIP文档免费下载次数

阅读免打扰

去除文档详情页间广告

专属身份标识

尊贵的VIP专属身份标识

高级客服

一对一高级客服服务

多端互通

电脑端/手机端权益通用