oracle体系结构------Oracle 使用PreparedStatement防止SQL注入---转载

Posted 风林山火

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle体系结构------Oracle 使用PreparedStatement防止SQL注入---转载相关的知识,希望对你有一定的参考价值。

一条效率差的sql语句,足以毁掉整个应用.

Statement是PreparedStatement的父接口,不进行预编译操作,减少了进行预编译的开销.单次运行PreparedStatement要比Statement要慢一些. 
PreparedStatement可以实现Statement的所有功能,但是之所以叫它预编译指令,是因为在创建它的一个对象时可以给定具有一定格式的SQL字符串,然后用它的setXXX方法给指定的SQL语句以填空的方式赋值,具有这样的特性后,它在多次执行一条固定格式的字符串时就很方便,也更效率.不像Statement那样每次执行都要先编译字符串在执行SQL了.

PreparedStatement需要服务器端的支持来提高效率.比如在Oracle上就会有显著效果,而mysql明确地说明了不支持PreparedStatement.
Oracle中会将所有的SQL语句先编译,叫做"执行计划",放在Oracle内部的一个特定的缓存中,每次遇到相同的SQL,就会先调用缓存中的,如果不预编译,每次都用Statement,那么每次都要编译,在缓冲中会有很多重复的"执行计划"影响数据库的性能.还有一点就是在使用setObject()的时候,记得一定要使用带targetSqlType参数的方法,来提高效率.

SQL注入攻击是利用设计上的漏洞,在目标服务器上运行SQL语句进行攻击,动态生成SQL语句时没有对用户输入的数据进行验证是SQL注入攻击得逞的主要原因.
对于JDBC而言,SQL注入攻击只对Statement有效,对PreparedStatement是无效的,这是因为PreparedStatement不允许在插入时改变查询的逻辑结构.
绕过验证,但这种手段只对Statement有效,对PreparedStatement无效.

如果有一条SQL语句: "select * from 表 where 用户名 = \'用户名\'"
Statement的SQL语句是这样写的: "select * from 表 where 用户名 = \'"+ 变量值 +"\'"
PreparedStatement的SQL语句是这样写的: "select * from 表 where 用户名 = ?" 然后对应?赋值
这样我们就发现输入 "aa\' or \'1\' = \'1"
Statement是将这个和SQL语句做字符串连接到一起执行
PreparedStatement是将 "aa\' or \'1\' = \'1" 作为一个字符串赋值给?,做为"用户名"字段的对应值,显然这样SQL注入无从谈起了.

实现机制不同,注入只对SQL语句的准备(编译)过程有破坏作用,而PreparedStatement已经准备好了,执行阶段只是把输入串作为数据处理,不再需要对SQL语句进行解析,准备,因此也就避免了SQL注入问题.

以上是关于oracle体系结构------Oracle 使用PreparedStatement防止SQL注入---转载的主要内容,如果未能解决你的问题,请参考以下文章

oracle系列oracle体系结构和用户管理

oracle 逻辑体系结构详解

oracle体系结构------Oracle 使用PreparedStatement防止SQL注入---转载

Oracle体系结构和用户管理

oracle数据库的物理存储结构有那些,它们各自的作用?

oracle体系结构-逻辑存储结构