当前位置:首页 » 编程语言 » 如何sql注入攻击

如何sql注入攻击

发布时间: 2024-11-21 05:27:19

sql注入攻击的原理以及防范措施

SQL注入攻击的原理及防范措施

SQL注入攻击,是发生在Web程序中数据库层的安全漏洞。其主要原因是程序对用户输入数据的合法性未进行判断和处理,导致攻击者在Web应用程序中插入恶意SQL语句,以非法操作数据库服务器执行非授权查询,进而获取数据信息。

SQL注入的原理主要包括以下几点:恶意拼接查询、利用注释执行非法命令、传入非法参数和添加额外条件。攻击者通过在用户输入中加入SQL命令,如果程序未进行检查,这些命令将被误认为正常执行,攻击者可执行非预期命令或访问未授权数据。

防范SQL注入方法主要有:严格区分用户权限、强制使用参数化语句、使用数据库安全参数、增强用户输入验证和多层环境下的身份验证。确保数据库操作安全,避免SQL注入攻击,需要开发者在设计时严格控制用户输入,使用安全的编程实践。

数字注入点、字符注入点和搜索注入点是常见的SQL注入类型,它们主要出现在链接地址、数据参数、cookie信息和HTTP请求头中。通过输入`AND 1=1`等来判断注入点是否有效,使用参数化语句可以防止大部分SQL注入攻击。

参数化语句将用户输入作为参数传递,而非直接嵌入SQL语句,这可以防止SQL注入攻击。SQL Server数据库提供了安全参数集合,有助于防止恶意注入攻击。验证用户输入内容、类型和长度,过滤特殊字符,是防范SQL注入的有效手段。

存储过程、陷阱账户等技术也可以在特定场景下用于防范SQL注入。在多层应用环境中,实施多层身份验证,确保各层协同工作,同时对用户输入进行严格验证,是防范SQL注入攻击的重要策略。

通过综合采用以上防范措施,可以显着降低SQL注入攻击的风险,保护数据安全。预防SQL注入攻击,是开发者、安全专家和所有依赖Web应用程序的组织应关注的核心问题。

❷ 什么是sql注入,如何防止sql注入

SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。具体来说,它是利用现有应用程序,将(恶意)的SQL命令注入到后台数据库引擎执行的能力,它可以通过在Web表单中输入(恶意)SQL语句得到一个存在安全漏洞的网站上的数据库,而不是按照设计者意图去执行SQL语句。比如先前的很多影视网站泄露VIP会员密码大多就是通过WEB表单递交查询字符暴出的,这类表单特别容易受到SQL注入式攻击.


SQL注入攻击实例:


比如在一个登录界面,要求输入用户名和密码:

可以这样输入实现免帐号登录:

用户名: ‘or 1 = 1 –

密 码:

点登陆,如若没有做特殊处理,那么这个非法用户就很得意的登陆进去了.(当然现在的有些语言的数据库API已经处理了这些问题)

这是为什么呢? 下面我们分析一下:

从理论上说,后台认证程序中会有如下的SQL语句:

String sql = "select * from user_table where username=

' "+userName+" ' and password=' "+password+" '";

当输入了上面的用户名和密码,上面的SQL语句变成:

SELECT * FROM user_table WHERE username=

'’or 1 = 1 -- and password='’

分析SQL语句:

条件后面username=”or 1=1 用户名等于 ” 或1=1 那么这个条件一定会成功;

然后后面加两个-,这意味着注释,它将后面的语句注释,让他们不起作用,这样语句永远都能正确执行,用户轻易骗过系统,获取合法身份。

这还是比较温柔的,如果是执行

SELECT * FROM user_table WHERE

username='' ;DROP DATABASE (DB Name) --' and password=''

….其后果可想而知…

防SQL注入:

下面我针对JSP,说一下应对方法:

1.(简单又有效的方法)PreparedStatement

采用预编译语句集,它内置了处理SQL注入的能力,只要使用它的setXXX方法传值即可。

使用好处:

(1).代码的可读性和可维护性.

(2).PreparedStatement尽最大可能提高性能.

(3).最重要的一点是极大地提高了安全性.

原理:

sql注入只对sql语句的准备(编译)过程有破坏作用

而PreparedStatement已经准备好了,执行阶段只是把输入串作为数据处理,

而不再对sql语句进行解析,准备,因此也就避免了sql注入问题.

2.使用正则表达式过滤传入的参数

要引入的包:

import java.util.regex.*;

正则表达式:

private String CHECKSQL = “^(.+)\sand\s(.+)|(.+)\sor(.+)\s$”;

判断是否匹配:

Pattern.matches(CHECKSQL,targerStr);

下面是具体的正则表达式:

检测SQL meta-characters的正则表达式 :

/(\%27)|(’)|(--)|(\%23)|(#)/ix

修正检测SQL meta-characters的正则表达式 :/((\%3D)|(=))[^ ]*((\%27)|(’)|(--)|(\%3B)|(:))/i

典型的SQL 注入攻击的正则表达式 :/w*((\%27)|(’))((\%6F)|o|(\%4F))((\%72)|r|(\%52))/ix

检测SQL注入,UNION查询关键字的正则表达式 :/((\%27)|(’))union/ix(\%27)|(’)

检测MS SQL Server SQL注入攻击的正则表达式:

/exec(s|+)+(s|x)pw+/ix

等等…..

3.字符串过滤

比较通用的一个方法:

(||之间的参数可以根据自己程序的需要添加)

publicstaticbooleansql_inj(Stringstr)
{
Stringinj_str="'|and|exec|insert|select|delete|update|
count|*|%|chr|mid|master|truncate|char|declare|;|or|-|+|,";
Stringinj_stra[]=split(inj_str,"|");
for(inti=0;i<inj_stra.length;i++)
{
if(str.indexOf(inj_stra[i])>=0)
{
returntrue;
}
}
returnfalse;
}

❸ 求教谁给讲讲SQL注入攻击的步骤

第一步:SQL注入点探测。探测SQL注入点是关键的第一步,通过适当的分析应用程序,可以判断什么地方存在SQL注入点。通常只要带有输入提交的动态网页,并且动态网页访问数据库,就可能存在SQL注入漏洞。如果程序员信息安全意识不强,采用动态构造SQL语句访问数据库,并且对用户输入未进行有效验证,则存在SQL注入漏洞的可能性很大。一般通过页面的报错信息来确定是否存在SQL注入漏洞。
第二步:收集后台数据库信息。不同数据库的注入方法、函数都不尽相同,因此在注入之前,我们先要判断一下数据库的类型。判断数据库类型的方法有很多,可以输入特殊字符,如单引号,让程序返回错误信息,我们根据错误信息提示进行判断,还可以使用特定函数来判断。
第三步:猜解用户名和密码。数据库中的表和字段命名一般都是有规律的,通过构造特殊的SQL语句在数据库中依次猜解出表名、字段名、字段数、用户名和密码。
第四步:查找Web后台管理入口。Web后台管理通常不对普通用户开放,要找到后台管理的登录网址,可以利用Web目录扫描工具快速搜索到可能的登录地址,然后逐一尝试,便可以找到后台管理平台的登录网址。
第五步:入侵和破坏。一般后台管理具有较高权限和较多的功能,使用前面已破译的用户名、密码成功登录后台管理平台后,就可以任意进行破坏,比如上传木马、篡改网页、修改和窃取信息等,还可以进一步提权,入侵Web服务器和数据库服务器。

热点内容
python嵌套字典遍历 发布:2025-01-29 06:38:14 浏览:746
stc单片机用什么编程 发布:2025-01-29 06:33:34 浏览:601
苹果手机改存储 发布:2025-01-29 06:29:52 浏览:374
文件夹中图片显示 发布:2025-01-29 06:13:52 浏览:794
linux命令执行脚本 发布:2025-01-29 06:02:51 浏览:138
编译报错的类反射调用 发布:2025-01-29 05:48:37 浏览:394
python3ubuntu 发布:2025-01-29 05:44:26 浏览:230
存储声音计算 发布:2025-01-29 05:36:00 浏览:914
我的世界网易版电脑服务器地址 发布:2025-01-29 05:10:43 浏览:711
php百度蜘蛛 发布:2025-01-29 05:10:36 浏览:383