程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle教程 >> OraclePL/SQL代碼加解密

OraclePL/SQL代碼加解密

編輯:Oracle教程

通過Oracle的PL/SQL代碼加密來保護業務邏輯在有些場合非常有用,簡單整理了下:

一. 通過Wrap命令來加密

二. 通過dbms_ddl包調用來加密

三. Oracle加密原理

四.加密代碼的破解

一. 通過Wrap命令來加密

1. 創建一個例子文件pro_wrap.sql

create or replace procedure pro_wrap is
begin
   dbms_output.put_line('Wrap Demo');
end pro_wrap;
2. 通過wrap命令來生成pld加密文件

wrap iname=c:\pk\pro_wrap.sql oname=c:\pk\pro_wrap.plb

c:\pk>wrap iname=c:\pk\pro_wrap.sql oname=c:\pk\pro_wrap.plb

PL/SQL Wrapper: Release 11.2.0.1.0- 64bit Production on 星期二 3月  25 21:58:20 2014

Copyright (c) 1993, 2009, Oracle.  All rights reserved.

Processing c:\pk\pro_wrap.sql to c:\pk\pro_wrap.plb
3.通過加密出來的文件pro_wrap.pld,生成存儲過程
c:\pk>sqlplus / as sysdba

SQL*Plus: Release 11.2.0.1.0 Production on 星期二 3月 25 22:17:19 2014

Copyright (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 options

SQL> set serveroutput on
SQL> @c:\pk\pro_wrap.plb

過程已創建。

SQL> exec pro_wrap;
Wrap Demo

PL/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=
可知確實是加密了的亂碼。

二。 通過dbms_ddl包調用來加密

Wrap是命令行方式,而dbms_ddl包是10g開始提供的一個代碼加密方面的包,可在代碼中調用,更靈活。

用 desc dbms_dll可看到具體的過程名及參數。 在這舉個簡單點的例子,加密一段代碼:

SQL> declare
  2    v_sql varchar2(1024);
  3    v_wrap varchar2(1024);
  4  begin
  5
  6  v_sql := 'create or replace procedure pro_wrap is
  7     begin
  8        dbms_output.put_line(\''Wrap Demo\'');
  9     end pro_wrap; ';
 10
 11     select dbms_ddl.wrap(v_sql)  into v_wrap from dual;
 12     dbms_output.put_line('==========================');
 13     dbms_output.put_line(v_sql);
 14     dbms_output.put_line('==========================');
 15     dbms_output.put_line(v_wrap);
 16  end;
 17  /
==========================
create or replace procedure pro_wrap is
        begin
           dbms_output.put_line(\'Wrap Demo\');
        end pro_wrap;
==========================
create or replace procedure pro_wrap wrapped
a000000
354
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
7
56 96
uO8D8aP98Qo6Xpynkx0It0gfVwQwg5nnm7+fMr2ywFwWFpfQlpbyVmmldIsG9cAy/tKGBsNp
abhSm7JK/iiyveeysx0GMCyuJOrwBIG4yPKcd2jkBDIu9tHc6iQfAqnKtc6lysam9kQ5phYZ
H50=

PL/SQL 過程已成功完成。
可看到直接加密前後的代碼相差還是很大的。

三. Oracle加密原理

Oracle 10g PL/SQL的wrap過程是對源碼先進行lz壓縮lzstr,然後對壓縮數據進行SHA-1運算得到40位的加密串shstr,然後將加密串與壓縮串拼接得到shstr+lzstr,然後對拼接後的字符串進行Oracle雙字符轉換(轉換表),最後將轉換後的字符串進行base64編碼,最終得到wrap的加密串。

四.加密代碼的破解

看高手整的文章

Oracle10g unwrap技術分析 By GENXOR
 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved