- 浏览: 89148 次
- 性别:
- 来自: 广州
最新评论
如果我们的SQL语句是固定的,但是参数会不断变化,那我们要怎么办呢?
首先看看以下的处理方式:
看起来我们是解决了我们的需要,但是其实这种写法会带来很严重的问题。
加入我们的userInputId是1 or 1=1,那么上面的SQL就会编程:
select * from user where userid = 1 or 1=1
这样,无论userid 为多少,我们都会返回所有用户记录。
这种动态SQL会造成我们著名的SQL注入(SQL Injection)的安全漏洞。这种漏洞除了可以窃取你的数据库记录外,严重的时候更能够破坏你的数据库结构,让你的数据库彻底毁掉。例如:
如果userInput是:
null);delete from user;--
那么,就会执行两条SQL命令,第一条就是创建一个user记录,第二条就会把所有user记录删掉!!
为了解决这种参数会变化但是SQL结构固定的动态SQL语句,jdbc提供了PreparedStatment这种操作方式:
这个接口会自动把一些非法字符串进行转换,防止用户串改操作语句。
而且使用PreparedStatement还有利于提高数据库效率,对于数据库,执行以下的两条SQL:
select * from user where userid = 1
select * from user where userid = 2
它会视为两条不同的SQL来执行,并且把执行过程分别存储起来,但是对于preparedStatement,它会记录:
select * from user where userid = ?
每次会根据参数返回操作结果,无论执行多少次都只会保留一份操作副本,能够有效节省数据库的编译SQL性能。
但是PreparedStatement也不是万能,假如我们的变化不是限制在参数上,就有问题,例如我们获取的数据表可能是动态的,或者where条件是动态的。那么我们怎么来处理这种情况并且有效防止SQL Injection呢?
很简单,但是却比较麻烦,就是限制用户的输入,并且不要直接把用户输入直接作为SQL凭借部分。
应用实例:
根据用户输入读取不同数据表的所有信息,要求:
用户输入:user时,获取所有用户表信息(user表)
用户输入:org时,获取所有组织信息(org表)
用户输入其它信息:返回所有新闻记录(news表)
实现:
利用这种方法和PreparedStatement就能够有效防止SQL注入。
无论日后是否使用ORM工具来操作数据库,都必须小心不要造成SQL注入漏洞,否则后果不堪设想。
首先看看以下的处理方式:
statement.executeQuery("select * from user where userid = "+userInputId);
看起来我们是解决了我们的需要,但是其实这种写法会带来很严重的问题。
加入我们的userInputId是1 or 1=1,那么上面的SQL就会编程:
select * from user where userid = 1 or 1=1
这样,无论userid 为多少,我们都会返回所有用户记录。
这种动态SQL会造成我们著名的SQL注入(SQL Injection)的安全漏洞。这种漏洞除了可以窃取你的数据库记录外,严重的时候更能够破坏你的数据库结构,让你的数据库彻底毁掉。例如:
statement.execute("insert int user values(......"+userInput+")");
如果userInput是:
null);delete from user;--
那么,就会执行两条SQL命令,第一条就是创建一个user记录,第二条就会把所有user记录删掉!!
为了解决这种参数会变化但是SQL结构固定的动态SQL语句,jdbc提供了PreparedStatment这种操作方式:
java.sql.PreparedStatement ps = conn.preparedStatement("select * from user where userid = ?"); ... ps.setInt(1,userInputId); ResultSet rs = ps.executeQuery(); ...
这个接口会自动把一些非法字符串进行转换,防止用户串改操作语句。
而且使用PreparedStatement还有利于提高数据库效率,对于数据库,执行以下的两条SQL:
select * from user where userid = 1
select * from user where userid = 2
它会视为两条不同的SQL来执行,并且把执行过程分别存储起来,但是对于preparedStatement,它会记录:
select * from user where userid = ?
每次会根据参数返回操作结果,无论执行多少次都只会保留一份操作副本,能够有效节省数据库的编译SQL性能。
但是PreparedStatement也不是万能,假如我们的变化不是限制在参数上,就有问题,例如我们获取的数据表可能是动态的,或者where条件是动态的。那么我们怎么来处理这种情况并且有效防止SQL Injection呢?
很简单,但是却比较麻烦,就是限制用户的输入,并且不要直接把用户输入直接作为SQL凭借部分。
应用实例:
根据用户输入读取不同数据表的所有信息,要求:
用户输入:user时,获取所有用户表信息(user表)
用户输入:org时,获取所有组织信息(org表)
用户输入其它信息:返回所有新闻记录(news表)
实现:
String sql = "select * from news"; if(userInput != null && userInput.equalsIgnoreCase("user")) sql = "select * from user"; if(userInput != null && userInput.equalsIgnoreCase("org")) sql = "select * from org";
利用这种方法和PreparedStatement就能够有效防止SQL注入。
无论日后是否使用ORM工具来操作数据库,都必须小心不要造成SQL注入漏洞,否则后果不堪设想。
发表评论
-
JAVA简单教程:数据库操作(二)
2010-03-10 11:09 2178今天来分析一下上次的 ... -
JAVA简单教程:数据库操作(一)
2010-03-05 16:40 1913最近依然是事情太多,一直无法坚持每天写份blog,对不起大家。 ... -
每天JAVA简单教学:枚举类
2010-02-02 14:41 1557今天给大家介绍一个JDK1.5的新特性:枚举类 先来看看以下 ... -
每天JAVA简单教学:类定义,成员类,抽象类及接口类
2010-01-27 11:58 1610最近忙得快疯掉了,而且着凉了病得好辛苦。。。不过今天还是能抓紧 ... -
每天JAVA简单教学:类型强转
2010-01-19 11:56 7620关于类型,我们说了不 ... -
每天JAVA简单教学:简单数据类型、地址比较和值比较
2010-01-18 11:48 2311昨天说了布朗运算,今天详细解释一下其中的==运算符和Objec ... -
每天JAVA简单教学:布朗运算
2010-01-15 14:46 2294布朗值,就是true和false,对于产生这两个值的运算,就是 ... -
每天JAVA简单教学:基本运算符
2010-01-13 18:09 1096今天来介绍一些基础运算符,先用int整数类型做介绍,最后用St ... -
每天简单JAVA教学:循环语法(二)
2010-01-07 10:07 1542自从JRE升级到1.5以后,java的for循环就更加方便了。 ... -
每天简单JAVA教学:循环语法(一)
2010-01-06 13:32 2096现在开始介绍跟变成有密切关系的Java语法,首先来介绍循环的写 ... -
每天简单JAVA教学:super和this
2010-01-05 11:49 1589因为实在太忙这么多天来都没时间上来写东西,感觉非常对不起大家。 ... -
每天简单JAVA教学:变量
2009-12-28 16:02 1277很抱歉,最近事忙,所以很少有时间上来写东西,希望大家见谅。 ... -
每天简单JAVA教学:类继承,重写、重构及重载,final的用法
2009-12-23 12:25 4041昨天事忙,所以没时间给大家写blog,抱歉一下。 今天说的内 ... -
每天简单JAVA教学:JVM的内存管理,static的用法
2009-12-21 14:41 2618今天的主题是介绍static和final这两个指示器的用法。但 ... -
每天简单JAVA教学:Modifier
2009-12-18 10:31 9578昨天给大家介绍了怎么进行同一个类里面的方法调用,今天将会给大家 ... -
每天简单JAVA教学:方法的调用
2009-12-17 14:59 1293继续我们的简单教学。 ... -
每天简单JAVA教学:第一个main程序分析
2009-12-16 23:12 1592上次我们轻松地完成了H ... -
每天简单JAVA教学:Hello World!
2009-12-16 00:39 1563以下文章只适合新手,新是很新很新的新。。。。自认对编程和JAV ...
相关推荐
`sqljdbc42.jar`是一个Java数据库连接(JDBC)驱动包,专为与SQL Server 2016配合使用而设计。JDBC是Java平台的一部分,允许Java开发者通过编写Java代码来访问和处理关系数据库。驱动包中的类和接口实现了JDBC规范,...
总之,这个Java大作业将涵盖数据库基础、JDBC使用、SQL语句编写、面向对象封装等多个核心知识点,对于提升Java程序员的技能和理解数据库操作有着极大的帮助。通过实际操作,你将能够更好地掌握这些概念,并能灵活地...
本文将深入探讨如何使用Java API(如JDBC)来连接到SQL Server数据库,并提供详细的步骤和示例代码。 首先,我们需要了解Java Database Connectivity (JDBC),这是Java标准库中的一个API,用于与各种类型的数据库...
接下来,`msbase.jar`、`mssqlserver.jar`和`msutil.jar`这三个JAR文件主要用于连接SQL Server。它们属于Microsoft提供的JDBC驱动,也被称为JDBC Type 4驱动。这些JAR包允许Java应用程序通过纯Java实现与SQL Server...
在Java编程中,连接MySQL数据库是一项基础且重要的任务,它使得Java应用程序能够与数据库进行交互,执行查询、更新等操作。本教程将详细介绍如何使用Java的JDBC(Java Database Connectivity)API来实现这一功能。 ...
10. **数据库操作**:如果包含JDBC相关代码,将涉及数据库连接、SQL查询、结果集处理等,可能是通过PreparedStatement或Statement执行SQL语句。 11. **GUI编程**:Java Swing或JavaFX库可用于构建图形用户界面,...
在IT领域,数据库管理和Java编程是两个至关重要的概念,它们之间的结合——Java嵌入式SQL,使得开发者可以在Java程序中直接执行SQL语句,实现对数据库的高效操作。本作业着重探讨了如何在Java应用程序中使用SQL进行...
【数据库——清华大学PPT】这份资料主要讲解了Java数据库连接的相关知识,适合初学者了解Java在数据库操作中的应用。在Java 2平台企业版(J2EE)的框架下,数据库连接是构建分布式应用程序的关键部分,它涉及到...
这里我们关注的是三个主要的数据库管理系统(DBMS)——MySQL、SQL Server和Oracle,以及它们对应的Java数据库连接(JDBC)驱动。这些驱动允许Java应用程序通过Java API来执行SQL查询和管理数据库。 1. **MySQL...
SQL Server驱动是Java应用程序连接Microsoft SQL Server数据库的关键组件。在Java环境中,我们通常使用JDBC(Java Database Connectivity)来实现数据库的访问。SQL Server提供的驱动主要有两种:sqljdbc.jar和sql...
在IT领域,数据库管理和操作是不可或缺的一部分,而Java作为广泛应用的编程语言,提供了与数据库交互的强大工具——Java Database Connectivity(JDBC)。本文将深入探讨如何使用Java和SQL进行数据库操作,以及JDBC...
本教程将围绕"DBUtil",一个简单的JDBC工具类,来介绍如何使用配置文件进行SQL连接和数据库的基本操作。这个工具类适用于初学者学习数据库连接管理。 首先,我们来看"db.properties"文件,这是用来存储数据库连接...
在IT行业中,将数据库数据导出到Excel文件是一种常见的需求,尤其在数据分析、报表生成或者数据...这个简单的Java程序演示了如何结合JDBC和Apache POI进行数据库与文件系统的交互,对于开发人员来说是一项实用的技能。
在IT行业中,Java是一种广泛应用的编程语言,尤其在企业级应用和数据库操作方面。本话题主要探讨如何使用Java来分离SQL Server数据库,这通常涉及到数据迁移、备份或复制等场景。下面将详细介绍这个过程涉及的关键...
### JAVA数据库基本操作:增删改查 在Java开发中,与数据库进行交互是一项非常重要的技能。无论是构建简单的Web应用还是复杂的企业级系统,开发者都需要掌握如何通过Java代码执行SQL命令来实现数据的增删改查操作。...
本示例将详细讲解如何利用SQL Server 2005(SQL2005)数据库与JavaServer Pages (JSP) 技术相结合,构建一个简单的登录注册系统。这个系统可以帮助初学者理解JSP与数据库交互的基本原理,同时掌握用户验证的关键步骤...
SQLJDBC驱动是微软提供的一个Java数据库连接(JDBC)驱动程序,专门用于与Microsoft SQL Server数据库进行交互。它是Java应用程序连接SQL Server的关键组件,使得开发者可以使用Java语言执行SQL查询、更新数据库记录...
在Java编程中,连接Oracle数据库是一项常见的任务,用于执行SQL查询、更新和其他数据库操作。`sqlHelper`类是一个自定义的工具类,旨在简化这个过程,提供一个方便、高效的接口来处理数据库交互。本篇文章将深入探讨...
通过阅读和分析这些源代码,学习者可以更直观地理解Java数据库编程的细节,如如何构造SQL语句、如何处理结果集以及如何实现事务控制等。 总之,这个小型超市管理系统是一个实用的学习资源,它将Java编程语言与SQL ...
### Java数据库连接(JDBC)详解 #### 一、引言 在Java开发中,与数据库进行交互是一项非常常见的任务。为了实现这一目标,Java提供了一套标准的API——Java Database Connectivity (JDBC),用于访问关系型数据库。...