通过Oracle的PL/SQL代码加密来保护业务逻辑在有些场合非常有用,简单整理了下:
- 一. 通过Wrap命令来加密
- 二. 通过dbms_ddl包调用来加密
- 三. Oracle加密原理
- 四.加密代码的破解
一. 通过Wrap命令来加密1. 创建一个例子文件pro_wrap.sqlcreate or replace procedure pro_wrap is
begin
dbms_output.put_line("Wrap Demo");
end pro_wrap;2. 通过wrap命令来生成pld加密文件wrap iname=c:pkpro_wrap.sql oname=c:pkpro_wrap.plbc:pk>wrap iname=c:pkpro_wrap.sql oname=c:pkpro_wrap.plbPL/SQL Wrapper: Release 11.2.0.1.0- 64bit Production on 星期二 3月 25 21:58:20 2014Copyright (c) 1993, 2009, Oracle. All rights reserved.Processing c:pkpro_wrap.sql to c:pkpro_wrap.plb3.通过加密出来的文件pro_wrap.pld,生成存储过程c:pk>sqlplus / as sysdbaSQL*Plus: Release 11.2.0.1.0 Production on 星期二 3月 25 22:17:19 2014Copyright (c) 1982, 2010, Oracle. All rights reserved.
连接到:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing optionsSQL> set serveroutput on
SQL> @c:pkpro_wrap.plb过程已创建。SQL> exec pro_wrap;
Wrap DemoPL/SQL 过程已成功完成。通过exec测试,可看到存储过程执行成功。4. 再验证下代码是否是加密了的.SQL> set newpage none
SQL> set heading off
SQL> set space 0
SQL> set pagesize 0
SQL> set trimout on
SQL> set trimspool on
SQL> set linesize 2500
SQL> SELECT dbms_metadata.get_ddl("PROCEDURE","PRO_WRAP") FROM dual; CREATE OR REPLACE PROCEDURE "SYS"."PRO_WRAP" wrapped
a000000
354
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
7
50 8d
cKb3/QEp0AIWOH/IyhxS2ffLbrUwg5nnm7+fMr2ywFwWFpfQlpbyVmmldIvAwDL+0oYJaWm4
UpuySv4osr3nsrMdBjAsriTqsoG4yGWcd2jPMi720eokHwKpyrXOpcrGpvY5pg2Gb0c=可知确实是加密了的乱码。
Oracle 11g新版本增加对原始数据文件验证过程Oracle 10g unwrap技术分析 By GENXOR相关资讯 PL/SQL
- PL/SQL之存储过程和函数 (今 14:09)
- PL/SQL Developer连接本地Oracle (07月27日)
- 【PL/SQL系列】Oracle存储过程使用 (04月23日)
| - PL/SQL Developer 使用技巧分享 (09月16日)
- PL/SQL实现Java中的split()方法的 (07月10日)
- 从一个案例看PL/SQL代码片的编译与 (03月04日)
|
本文评论 查看全部评论 (0)