如何防范SQL注入漏洞
- 格式:docx
- 大小:22.73 KB
- 文档页数:7
避免SQL注入三种主要方法SQL注入是一种常见的安全漏洞,攻击者可以通过恶意构造的输入数据来攻击数据库系统,获取敏感信息或者修改数据。
为了避免SQL注入攻击,可以采取以下三种主要方法:1.使用参数化查询参数化查询是最有效的防止SQL注入攻击的方法之一、在使用参数化查询时,所有的用户输入都会被作为参数传递给SQL语句,而不是直接拼接到SQL语句中。
这样可以防止攻击者将恶意的SQL代码插入到查询语句中。
例如,使用Java的JDBC进行数据库操作时,可以使用PreparedStatement接口来实现参数化查询:```String sql = "SELECT * FROM users WHERE username = ? AND password = ?";PreparedStatement statement =connection.prepareStatement(sql);statement.setString(1, username);statement.setString(2, password);ResultSet resultSet = statement.executeQuery(;```在这个例子中,通过使用`?`占位符来指定参数的位置,然后使用`setString(`方法将真正的参数值绑定到查询语句中。
这样无论用户输入的是什么,都不会破坏原有的SQL语句结构。
2.输入验证和过滤输入验证和过滤是防止SQL注入攻击的重要手段之一、通过对用户输入数据进行验证和过滤,可以排除潜在的安全风险。
在验证用户输入时,应该注意以下几点:-长度验证:限制输入的最大长度,以防止输入超出预期范围。
-数据类型验证:检查输入的数据是否符合预期的数据类型,如数字、日期等。
-白名单验证:只允许特定的字符或者字符集合,排除其他潜在的恶意字符。
在过滤用户输入时,可以使用一些常见的函数或方法,比如:- `mysqli_real_escape_string(`:用于转义特殊字符,防止SQL注入。
SQL注入的原理及防范SQL注入(SQL Injection)是一种常见的安全漏洞,攻击者通过在输入框或URL参数中输入恶意SQL语句来执行未经授权的数据库操作。
SQL注入的原理是攻击者通过构造恶意的SQL语句,将其插入到应用程序的输入参数中,利用应用程序对用户输入数据的信任来获取或修改数据库中的信息。
要防范SQL注入攻击,开发人员和系统管理员需要遵循以下几个原则:1.使用参数化查询:参数化查询是防范SQL注入攻击最有效的方式之一、通过使用参数化查询,可以将用户输入的数据作为参数传递给SQL查询,而不是直接将用户输入的数据拼接到SQL语句中。
这样可以避免攻击者利用恶意SQL语句来执行未经授权的数据库操作。
2.输入验证和过滤:对用户输入数据进行验证和过滤是防范SQL注入攻击的另一个重要措施。
在接收用户输入数据之前,应该对数据进行验证,确保数据格式符合预期,并在需要时进行过滤,去除不安全的字符。
例如,可以使用正则表达式来验证输入数据是否符合特定的格式,或使用内置的函数来过滤危险字符。
3.最小化权限:在数据库的设计中,应该尽量采用最小权限原则,即只给予应用程序访问数据库所需的最小权限。
这样即使攻击者成功注入恶意SQL语句,也只能执行受限的操作,减少损失。
4.错误消息处理:在应用程序中,应该避免直接将数据库错误信息暴露给用户。
攻击者可以通过数据库错误信息来获取有关数据库结构和操作的信息,从而更有针对性地进行攻击。
应该对错误信息进行适当处理,显示友好的提示信息而不是详细的错误信息。
5.定期更新和维护:对应用程序和数据库进行定期的更新和维护也是防范SQL注入攻击的有效措施。
及时修补系统漏洞和更新软件版本可以减少攻击者利用已知漏洞进行注入攻击的机会。
总的来说,防范SQL注入攻击需要开发人员和系统管理员共同努力,采取多种手段综合防范。
只有在建立完善的安全机制和规范的开发流程的基础上,才能有效地防止SQL注入这种常见的安全威胁,保护应用程序和数据库的安全。
六个建议防止SQL注入式攻击SQL注入式攻击是一种利用应用程序对输入数据进行不当处理的安全漏洞,攻击者通过在输入数据中插入恶意的SQL语句来执行非预期的数据库操作。
为了防止SQL注入式攻击,以下是六个建议:1.使用预编译语句:使用预编译语句可以将SQL查询和参数分开,避免在构造SQL语句时拼接输入数据。
预编译语句会将输入数据视为参数,而不会将其作为SQL语句的一部分。
这样可以有效防止注入攻击。
2.参数化查询:使用参数化查询可以将输入参数绑定到预编译的SQL语句中,而不是直接将输入数据插入SQL语句中。
参数化查询可以确保输入数据在传递给数据库之前被正确地转义和处理,从而防止注入攻击。
3.输入验证和过滤:对于从用户接收的输入数据,进行验证和过滤是非常重要的。
输入验证可以确保输入数据符合预期的格式和类型,而过滤则可以去除输入数据中的特殊字符和关键字。
这样可以减少注入攻击的可能性。
4.最小权限原则:在配置数据库时,要将应用程序连接到数据库的账户权限设置为最小权限,避免使用具有过高权限的账户。
这样即使发生了注入攻击,攻击者也只能执行被授权的最低操作,减少了攻击的影响范围。
5.日志记录和监控:实施日志记录和监控机制可以帮助及时发现和响应潜在的SQL注入攻击。
通过监控数据库访问日志和用户行为,可以识别异常的查询和行为模式,及时采取措施防止攻击或限制其影响。
6.定期更新和维护:定期更新和维护数据库和应用程序可以帮助修补已知的安全漏洞和软件缺陷。
及时安装数据库和应用程序的补丁可以减少攻击者利用已知漏洞进行注入攻击的机会。
总之,通过使用预编译语句、参数化查询、输入验证和过滤、最小权限原则、日志记录和监控以及定期更新和维护,可以有效地防止SQL注入式攻击,并提高系统的安全性。
同时,敏感数据的保护也是很重要的,例如加密存储敏感信息等。
综合使用以上方法可以最大程度地降低SQL注入攻击的风险。
SQL注入攻击与防范措施引言:在当今数字化时代,互联网应用广泛应用于各行各业。
然而,与之相应的网络安全威胁也随之而来。
SQL注入攻击是其中一种常见的网络攻击手段,它利用不当的输入验证和编码错误,通过恶意注入SQL代码来绕过应用程序的安全机制,实施各种危害行为。
本文将分析SQL注入攻击的原理,并提出一些有效的防范措施。
一、SQL注入攻击的原理SQL注入攻击是指黑客通过在用户输入的数据中注入恶意的SQL代码,从而实现非法访问、窃取敏感信息,甚至控制数据库服务器的攻击方式。
其原理如下:1. 输入验证不严格:当应用程序对用户输入的数据没有进行充分的验证时,用户可以在输入中插入SQL语句,从而改变程序的执行逻辑。
2. 编码错误:当应用程序在处理用户输入时出现编码错误时,用户可以通过插入特殊的字符来绕过输入验证,注入恶意的SQL代码。
3. 错误信息泄露:当应用程序把数据库返回的错误信息直接显示给用户时,黑客可以利用这些错误信息来获取数据库的结构和内容,从而更好地实施SQL注入攻击。
二、SQL注入攻击的危害SQL注入攻击可以对数据库服务器造成严重的危害,包括但不限于以下几个方面:1. 非法访问:黑客可以通过注入恶意的SQL代码,绕过身份验证,访问未经授权的数据库内容。
2. 数据泄露:黑客可以通过注入SQL代码,获取数据库中的敏感信息,例如用户的密码、信用卡信息等。
3. 数据篡改:黑客可以通过注入SQL代码,修改数据库中的数据,导致数据的不一致性和可靠性的丧失。
4. 拒绝服务:黑客可以通过注入恶意的SQL代码,导致数据库服务器负载过载,从而使合法用户无法正常访问。
三、防范SQL注入攻击的措施为了防止SQL注入攻击,我们可以采取一系列措施来确保应用程序的安全。
1. 输入验证和过滤:对用户输入的数据进行充分的验证和过滤,确保只接受合法的数据。
可以使用正则表达式、白名单等方法来过滤输入数据。
2. 参数化查询:使用参数化查询或预处理语句来构建SQL语句,确保用户输入的数据不会被误解为SQL代码的一部分。
SQL注入入侵防范技术措施SQL注入是一种常见的web应用漏洞,攻击者利用输入的数据篡改SQL查询语句,从而获取、修改或删除数据库中的数据。
为了防范SQL注入,需要采取一系列的技术措施来保护web应用的安全性。
以下是常见的SQL注入防范技术措施:1.使用参数化查询:参数化查询是一种通过将用户输入的值作为参数传递给预编译的SQL语句来执行查询的方法。
这样可以避免将用户输入直接拼接到SQL语句中,从而防止注入攻击。
3.拒绝动态SQL:尽可能避免使用动态SQL语句,尤其是直接拼接用户输入的内容。
如果必须使用动态SQL,确保对输入进行严格的验证和过滤,以及使用参数化查询来执行动态SQL。
4.最小权限原则:给数据库用户分配最低权限的角色,避免使用具有过高权限的数据库用户。
限制数据库用户的访问权限可以减少攻击者成功入侵数据库的可能性。
5.日志监控与分析:记录所有SQL查询的日志,并对其进行监控和分析。
通过对日志进行审查,可以发现潜在的SQL注入攻击,并及时采取相应的措施来应对。
6. 使用防火墙:在数据库和web服务器之间设置防火墙,限制对数据库的直接访问。
只允许web服务器的IP地址访问数据库,并且禁止来自外部的直接连接。
这样可以降低数据库被攻击的风险。
7. 定期更新和维护:及时更新数据库软件和相关的补丁程序,以及web应用程序。
这样可以修复已知的安全漏洞,并提高系统的安全性。
另外,定期对数据库进行巡检和维护,确保数据库的完整性和安全性。
8. 使用安全编码实践:采用安全编码的最佳实践来开发web应用程序,例如避免在页面中显示详细的错误信息,防止敏感信息泄露等。
了解和遵守安全编码的指导原则,可以减少SQL注入等漏洞的出现。
9.安全训练和意识提高:加强员工的安全培训,提高对SQL注入等安全漏洞的认识和意识。
建立一个安全意识的文化,让员工充分理解安全风险,并知道如何正确地处理用户输入和数据库操作。
总之,SQL注入是一种常见的web应用漏洞,但采取正确的技术措施可以有效地防范注入攻击。
java sql注入防范措施
1.在SQL注入攻击中,黑客会利用web表单或URL中的查询字符串,通过注入特定的SQL代码来执行恶意操作。
为了防范SQL注入攻击,我们可以采取以下措施:
1.1验证用户输入的数据
在表单提交或URL中,验证用户输入的数据是否有效。
例如,验证用户输入的数据是否为合法的SQL语句。
1.2使用参数化SQL
SQL注入攻击的一个常见方式是,黑客会在查询字符串中包含特定的SQL代码。
通过使用参数化SQL,我们可以避免在查询字符串中直接指定SQL代码,从而减少注入攻击的可能性。
1.3使用函数
函数是在SQL语句中使用的特殊关键字。
函数可以执行特定的操作,例如对数据进行排序或过滤。
函数的使用可以防止黑客利用注入攻击执行恶意操作。
1.4使用预处理函数
预处理函数可以帮助我们防止SQL注入攻击。
预处理函数会在SQL语句的执行之前进行处理,从而防止黑客利用注入攻击执行恶意操作。
1.5使用数据库安全机制
数据库安全机制是数据库中的一项安全功能。
数据库安全机制可以防止黑客利用注入攻击执行恶意操作。
2.防范SQL注入的其他方法
除了以上措施之外,我们还可以采取以下措施来防范SQL注入攻击:。
sql注入漏洞防范方法
下面是一些预防SQL注入漏洞的方法:
1. 输入验证:校验用户输入的数据,确保输入符合预期的格式和长度。
可以使用正则表达式进行输入验证,或使用现成的验证函数。
2. 参数化查询:使用参数化查询的方式来执行SQL语句。
参数化查询会将用户输入的数据作为参数传递给数据库引擎,而不是直接将输入拼接到SQL字符串中。
这样可以有效防止SQL注入攻击。
3. 预编译语句:在使用编程语言访问数据库时,可以使用预编译语句来执行SQL 操作。
预编译语句会在执行之前进行编译,将SQL语句和参数分开存储,可以有效防止SQL注入攻击。
4. 限制数据库权限:给数据库用户设置最小的权限,限制其对数据库的操作范围。
只给予必要的权限,可以降低攻击者获取敏感数据的可能性。
5. 安全编码实践:编写安全的代码,避免使用动态拼接SQL字符串的方式进行数据库查询。
使用ORM框架或其他安全的数据库访问方式,可以帮助避免SQL 注入漏洞。
6. 日志记录和监测:记录用户的操作和异常访问行为,并定期监测数据库的访
问情况。
及时发现异常行为,可以及早采取措施防止进一步的攻击。
7. 数据库安全更新:及时更新数据库引擎和相关的安全补丁,以防止已知的漏洞被攻击者利用。
8. 定期安全审计:定期进行安全审计,检查数据库和应用程序的安全性,修复和预防可能存在的安全漏洞。
总之,预防SQL注入漏洞需要综合使用输入验证、参数化查询、权限控制、安全编码实践和定期审计等多种措施,以确保应用程序和数据库的安全性。
防范sql注入攻击的方法
1. 使用参数化查询:使用参数化查询可以防止用户输入的数据被直接拼接成SQL语句,从而避免SQL注入攻击。
2. 输入验证和过滤:对用户输入的数据进行验证和过滤,只允许特定类型的数据通过,例如数字、字母等,可以有效防止SQL注入攻击。
3. 限制数据库用户权限:合理设置数据库用户的权限,只将必要的操作权限赋予用户,可以减小被攻击的风险。
4. 使用ORM框架:使用ORM(Object-Relational Mapping)框架可以帮助开发者减少直接与数据库交互的机会,从而减少SQL注入的可能性。
5. 定期更新数据库软件和应用程序:及时更新数据库软件和应用程序可以修复已知的SQL注入漏洞,增强系统的安全性。
6. 日志监控:监控数据库访问日志,及时发现异常操作,及时采取措施进行阻止。
7. 安全编程规范:开发人员在编写程序时要遵循安全编程规范,避免直接拼接用户输入的数据到SQL语句中。
8. 使用Web应用防火墙(WAF):使用WAF可以对输入数据进行检测和过滤,防止恶意的SQL注入攻击。
如何防范SQL注入漏洞SQL注入漏洞是一种常见的网络安全漏洞,攻击者通过在数据库查询中插入恶意的SQL语句,来获取或修改数据库中的数据。
为了防范SQL注入漏洞,以下是一些常用的防范方法:1.使用参数化查询参数化查询是防范SQL注入最有效的方法之一、通过使用参数化查询,可以将用户输入的数据作为参数传递给查询语句,而不是将用户输入的数据直接拼接到查询语句中。
使用参数化查询可以防止攻击者在输入中注入恶意的SQL代码。
例如,在使用SQL语句查询用户名和密码的过程中,可以使用参数化查询来替代直接拼接字符串的方式:```SELECT * FROM users WHERE username = :username AND password= :password;```这里的`:username`和`:password`是参数,可以通过编程语言的API来传递具体的值。
2.输入验证和过滤对于用户输入,应该进行适当的验证和过滤,以确保输入的数据符合预期的格式和范围。
例如,如果预期输入的是一个整数,则可以使用正则表达式验证用户输入的是否为整数,如果不是,则应该拒绝请求或给予错误提示。
此外,对于一些特殊字符,如单引号、双引号、分号等,可以进行过滤或转义。
例如,可以使用转义字符转义单引号,将其作为普通字符处理,而不是作为SQL语句的一部分。
3.最小权限原则为了减少风险,数据库用户应该被授予最小的权限,以限制其操作的范围。
例如,如果一个用户只需要查询一些表的数据,那么应该只给予该用户查询权限,而不应该给予修改、删除等权限。
此外,对于不同的应用,应该使用不同的数据库账户,以确保数据库的安全性。
这样,即使一个账户存在SQL注入漏洞,也不会对其他应用造成影响。
4.使用ORM框架ORM(对象关系映射)框架可以帮助开发人员避免直接编写SQL语句,从而减少SQL注入漏洞的风险。
ORM框架会自动将对象和数据库表进行映射,同时提供了参数化查询等安全特性。
Java 避免 SQL 注入的方法在 Web 应用程序中,SQL 注入是一种常见的安全漏洞,黑客可以通过注入恶意 SQL 语句来获取未授权的访问权限或者窃取敏感数据。
本文将介绍在 Java 应用程序中如何避免 SQL 注入的攻击。
下面是本店铺为大家精心编写的5篇《Java 避免 SQL 注入的方法》,供大家借鉴与参考,希望对大家有所帮助。
《Java 避免 SQL 注入的方法》篇1SQL 注入是一种常见的 Web 应用程序安全漏洞,黑客可以通过在 Web 应用程序的输入框中注入恶意 SQL 语句来获取未授权的访问权限或者窃取敏感数据。
在 Java 应用程序中,为了避免 SQL 注入的攻击,开发者可以采取以下几种方法:1. 对输入参数进行校验在 Java 应用程序中,开发者应该对所有的输入参数进行校验,确保输入参数的格式和类型正确。
例如,如果输入参数是一个整数,则应该使用 Integer 类型来进行校验,如果输入参数是一个字符串,则可以使用正则表达式来进行校验。
通过对输入参数进行校验,可以避免恶意注入攻击。
2. 使用参数化的 SQL 语句在 Java 应用程序中,使用参数化的 SQL 语句可以避免 SQL 注入的攻击。
参数化的 SQL 语句可以使用Java.sql.PreparedStatement 类来实现。
在参数化的 SQL 语句中,所有的输入参数都作为一个参数传递给 PreparedStatement 对象,而不是直接拼接在 SQL 语句中。
这样可以避免黑客通过注入恶意SQL 语句来窃取数据或者破坏应用程序。
3. 使用存储过程在 Java 应用程序中,使用存储过程可以避免 SQL 注入的攻击。
存储过程是一种预编译的 SQL 语句,它可以在数据库中执行,而不需要拼接 SQL 语句。
使用存储过程可以避免黑客通过注入恶意 SQL 语句来窃取数据或者破坏应用程序。
4. 避免使用拼接 SQL 语句在 Java 应用程序中,避免使用拼接 SQL 语句可以避免 SQL 注入的攻击。
如何防范SQL注入漏洞,下面给出4个函数,足够你抵挡一切SQL注入漏洞!读懂代码,你就能融会贯通。
注意要对所有的request对象进行过滤:包括 request.cookie, request.Server Variables 等等容易被忽视的对象:function killn(byval s1) '过滤数值型参数if not isnumeric(s1) thenkilln=0elseif s1<0 or s1>2147483647 thenkilln=0elsekilln=clng(s1)end ifend ifend functionfunction killc(byval s1) 过滤货币型参数if not isnumeric(s1) thenkillc=0elsekillc=formatnumber(s1,2,-1,0,0)end ifend functionfunction killw(byval s1) '过滤字符型参数if len(s1)=0 thenkillw=""elsekillw=trim(replace(s1,"'",""))end ifend functionfunction killbad(byval s1) 过滤所有危险字符,包括跨站脚本If len(s1) = 0 thenkillbad=""elsekillbad = trim(replace(replace(replace(replace(replace(replace(replace(replace(s1,Chr(10), "<br>"),Chr(34), """), ">", ">"), "<", "<"), "&", "&"),chr(39),"'"),chr(32)," "),chr(13),""))end ifend functionSQL注入攻击的种类和防范手段观察近来的一些安全事件及其后果,安全专家们已经得到一个结论,这些威胁主要是通过SQL注入造成的。
虽然前面有许多文章讨论了SQL注入,但今天所讨论的内容也许可帮助你检查自己的服务器,并采取相应防范措施。
SQL注入攻击的种类知彼知己,方可取胜。
首先要清楚SQL注入攻击有哪些种类。
1.没有正确过滤转义字符在用户的输入没有为转义字符过滤时,就会发生这种形式的注入式攻击,它会被传递给一个SQL语句。
这样就会导致应用程序的终端用户对数据库上的语句实施操纵。
比方说,下面的这行代码就会演示这种漏洞:statement := "SELECT * FROM users WHERE name = '" + userName + "'; "这种代码的设计目的是将一个特定的用户从其用户表中取出,但是,如果用户名被一个恶意的用户用一种特定的方式伪造,这个语句所执行的操作可能就不仅仅是代码的作者所期望的那样了。
例如,将用户名变量(即username)设置为:a' or 't'='t,此时原始语句发生了变化:SELECT * FROM users WHERE name = 'a' OR 't'='t';如果这种代码被用于一个认证过程,那么这个例子就能够强迫选择一个合法的用户名,因为赋值't'='t永远是正确的。
在一些SQL服务器上,如在SQL Server中,任何一个SQL命令都可以通过这种方法被注入,包括执行多个语句。
下面语句中的username的值将会导致删除“users”表,又可以从“data”表中选择所有的数据(实际上就是透露了每一个用户的信息)。
a'; DROP TABLE users; SELECT * FROM data WHERE name LIKE '%这就将最终的SQL语句变成下面这个样子:SELECT * FROM users WHERE name = 'a'; DROP TABLE users; SELECT * FROM DATA WHERE name LIKE '%';其它的SQL执行不会将执行同样查询中的多个命令作为一项安全措施。
这会防止攻击者注入完全独立的查询,不过却不会阻止攻击者修改查询。
2.Incorrect type handling如果一个用户提供的字段并非一个强类型,或者没有实施类型强制,就会发生这种形式的攻击。
当在一个SQL语句中使用一个数字字段时,如果程序员没有检查用户输入的合法性(是否为数字型)就会发生这种攻击。
例如:statement := "SELECT * FROM data WHERE id = " + a_variable + "; "从这个语句可以看出,作者希望a_variable是一个与“id”字段有关的数字。
不过,如果终端用户选择一个字符串,就绕过了对转义字符的需要。
例如,将a_variable设置为:1; DROP TABLE users,它会将“users”表从数据库中删除,SQL语句变成:SELECT * FROM DATA WHERE id = 1; DROP TABLE users;3.数据库服务器中的漏洞有时,数据库服务器软件中也存在着漏洞,如MYSQL服务器中mysql_real_escape_string()函数漏洞。
这种漏洞允许一个攻击者根据错误的统一字符编码执行一次成功的SQL注入式攻击。
4.盲目SQL注入式攻击当一个Web应用程序易于遭受攻击而其结果对攻击者却不见时,就会发生所谓的盲目SQL注入式攻击。
有漏洞的网页可能并不会显示数据,而是根据注入到合法语句中的逻辑语句的结果显示不同的内容。
这种攻击相当耗时,因为必须为每一个获得的字节而精心构造一个新的语句。
但是一旦漏洞的位置和目标信息的位置被确立以后,一种称为Absinthe的工具就可以使这种攻击自动化。
5.条件响应注意,有一种SQL注入迫使数据库在一个普通的应用程序屏幕上计算一个逻辑语句的值:SELECT booktitle FROM booklist WHERE bookId = 'OOk14cd' AND 1=1这会导致一个标准的面面,而语句SELECT booktitle FROM booklist WHERE bookId = 'OOk14cd' AND 1=2在页面易于受到SQL注入式攻击时,它有可能给出一个不同的结果。
如此这般的一次注入将会证明盲目的SQL注入是可能的,它会使攻击者根据另外一个表中的某字段内容设计可以评判真伪的语句。
6.条件性差错如果WHERE语句为真,这种类型的盲目SQL注入会迫使数据库评判一个引起错误的语句,从而导致一个SQL错误。
例如:SELECT 1/0 FROM users WHERE username='Ralph'。
显然,如果用户Ralph存在的话,被零除将导致错误。
7.时间延误时间延误是一种盲目的SQL注入,根据所注入的逻辑,它可以导致SQL引擎执行一个长队列或者是一个时间延误语句。
攻击者可以衡量页面加载的时间,从而决定所注入的语句是否为真。
以上仅是对SQL攻击的粗略分类。
但从技术上讲,如今的SQL注入攻击者们在如何找出有漏洞的网站方面更加聪明,也更加全面了。
出现了一些新型的SQL攻击手段。
黑客们可以使用各种工具来加速漏洞的利用过程。
我们不妨看看the Asprox Trojan这种木马,它主要通过一个发布邮件的僵尸网络来传播,其整个工作过程可以这样描述:首先,通过受到控制的主机发送的垃圾邮件将此木马安装到电脑上,然后,受到此木马感染的电脑会下载一段二进制代码,在其启动时,它会使用搜索引擎搜索用微软的ASP技术建立表单的、有漏洞的网站。
搜索的结果就成为SQL注入攻击的靶子清单。
接着,这个木马会向这些站点发动SQL注入式攻击,使有些网站受到控制、破坏。
访问这些受到控制和破坏的网站的用户将会受到欺骗,从另外一个站点下载一段恶意的JavaScript代码。
最后,这段代码将用户指引到第三个站点,这里有更多的恶意软件,如窃取口令的木马。
以前,我们经常警告或建议Web应用程序的程序员们对其代码进行测试并打补丁,虽然SQL注入漏洞被发现和利用的机率并不太高。
但近来攻击者们越来越多地发现并恶意地利用这些漏洞。
因此,在部署其软件之前,开发人员应当更加主动地测试其代码,并在新的漏洞出现后立即对代码打补丁。
防御和检查SQL注入的手段1.使用参数化的过滤性语句要防御SQL注入,用户的输入就绝对不能直接被嵌入到SQL语句中。
恰恰相反,用户的输入必须进行过滤,或者使用参数化的语句。
参数化的语句使用参数而不是将用户输入嵌入到语句中。
在多数情况中,SQL语句就得以修正。
然后,用户输入就被限于一个参数。
下面是一个使用Java和JDBC API例子:PreparedStatement prep = conn.prepareStatement("SELECT * FROM USERS WHERE PASSWORD=?");prep.setString(1, pwd);总体上讲,有两种方法可以保证应用程序不易受到SQL注入的攻击,一是使用代码复查,二是强迫使用参数化语句的。
强迫使用参数化的语句意味着嵌入用户输入的SQL语句在运行时将被拒绝。
不过,目前支持这种特性的并不多。
如H2 数据库引擎就支持。
2.还要避免使用解释程序,因为这正是黑客们借以执行非法命令的手段。
3.防范SQL注入,还要避免出现一些详细的错误消息,因为黑客们可以利用这些消息。
要使用一种标准的输入确认机制来验证所有的输入数据的长度、类型、语句、企业规则等。
4.使用专业的漏洞扫描工具。
但防御SQL注入攻击也是不够的。
攻击者们目前正在自动搜索攻击目标并实施攻击。
其技术甚至可以轻易地被应用于其它的Web架构中的漏洞。
企业应当投资于一些专业的漏洞扫描工具,如大名鼎鼎的Acunetix的Web漏洞扫描程序等。