亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

oracle下加密存儲過程的方法

2024-08-29 13:57:19
字體:
來源:轉載
供稿:網友
方法1: X:/oracle/ora81/bin/wrap   iname=XXX   oname=XXX   

方法2:9i在win2000下使用wrap加密存儲過程,10g可以用加密包dbms_ddl.wrap或dbms_ddl.create_wrapped。

11.5.1 在win2000下使用wrap加密存儲過程
wrap.bat
rem 使用方法:wrap 待加密的文件名
set NLS_LANG=AMERICAN_AMERICA.USACII7
wrap.exe iname=%1
pause
11.5.2 WRAP 程序包(10.2版本)
PL/SQL 程序單元經常包含關于公司流程和商業秘密的非常敏感和機密的信息,這使得它們與表相類似,成為受保護的實體組。為防止未經授權而查看源代碼的情況,我們要經常使用 wrap 命令行實用程序,這將使程序變得很混亂。 
只有在創建 PL/SQL 腳本后才能調用 wrap;該實用程序將輸入的明文打包為一個文件。但是,在某些情況下,您可能希望在 PL/SQL 代碼中動態生成包裝。在這種情況下,因為還不存在源文件,不能調用 wrap 實用程序。 
由于 Oracle 數據庫 10g 第 2 版提供了一個供應程序包,您可以使用它創建代碼,并進行打包。該程序包補充(而不是替代)了 wrap 實用程序。而后者仍然適合于希望使用命令行來快速打包大量源文件的情況。 
例如,假設您希望以打包形式創建簡單的過程 p1。
create or replace procedure p1 as 
begin
null; 
end;
在 PL/SQL 單元中,您可以使用以下命令以打包方式動態地創建這一過程:
begin
dbms_ddl.create_wrapped 
('create or replace procedure p1 as begin null; end;')
end;
/
現在您希望確認打包過程。您可以從字典中選擇源文本。 
SQL> select text from user_source where name = 'P1';

Text
-----------------------------------------------------------------
procedure p1 wrapped
a000000
369
abcd
abcd
……等等……
第一行 procedure p1 wrapped 是確認以打包方式創建過程。如果您利用 DBMS_METADATA.GET_DDL() 函數來獲取該過程的 DDL,則仍然會看到源代碼已被打包。 
有時您可能會有略微不同的需求;例如,您可能要生成 PL/SQL 代碼,但不想創建過程。在這種情況下,您可以將其保存在一個文件或表中,以便以后執行。但是因為以上方法創建了過程,所以該方法在這里行不通。所以您需要在程序包中調用另一個函數:
SQL> select dbms_ddl.wrap
2 ('create or replace procedure p1 as begin null; end;')
3 from dual
4 /

DBMS_DDL.WRAP('CREATEORREPLACEPROCEDUREP1ASBEGINNULL;END;')
----------------------------------------------------------------------
create or replace procedure p1 wrapped
a000000
369
abcd
abcd
... and so on ...
WRAP 函數的輸出是一個可傳遞的參數,它代表著 PL/SQL 代碼的打包輸出結果。該參數可以保存在純文件文件或表中,可以在以后執行。如果您生成的代碼要在其他地方部署,并且必須要保證代碼的安全性,則這種方法很有用。 
如果您可以將所存儲代碼的全部文本作為一個 varchar2 數據類型(大小限制為 32K)來傳遞,則這一方法可以正常工作。如果 PL/SQL 代碼超過 32K,則您必須使用一種略微不同的方法:接受一個集合變量作為輸入。 
在這里您可以使用一個供應的數據類型:程序包 DBMS_SQL 中的 varchar2。這是一個集合數據類型 (TABLE OF VARCHAR2),表的每個單元都接收多達 32K 的文本;可隨意增加該表所含的單元數,以滿足您的需要。例如,假設您必須包裝一個名為 myproc 的非常長的過程,其定義如下: 
create or replace procedure myproc as
l_key VARCHAR2(200);
begin
l_key := 'ARUPNANDA';
end;
當然,這根本不是一個非常長的過程;但是為了示范起見,假設它很長。為了將其創建為打包形式,您要執行以下的 PL/SQL 塊: 
1 declare
2 l_input_code dbms_sql.varchar2s;
3 begin
4 l_input_code (1) := 'Array to hold the MYPROC';
5 l_input_code (2) := 'create or replace procedure myproc as ';
6 l_input_code (3) := ' l_key VARCHAR2(200);';
7 l_input_code (4) := 'begin ';
8 l_input_code (5) := ' l_key := ''ARUPNANDA'';';
9 l_input_code (6) := 'end;';
10 l_input_code (7) := 'the end';
11 sys.dbms_ddl.create_wrapped (
12 ddl => l_input_code,
13 lb => 2,
14 ub => 6
15 );
16* end;
在這里我們定義了一個變量 l_input_code 來保存輸入的明文代碼。在第 4 行到第 10 行中,我們用要打包的代碼來填充這些行。在本示例中,同樣為了簡單起見,我使用了非常短的行。實際上,您可能要使用非常長的行,其大小多達 32KB。同樣,我在數組中只使用了 7 個單元;實際上您可能要使用若干單元來填充全部代碼。 
第 11 到第 15 行表明我如何調用該過程,以便將該過程創建為打包形式。在第 12 行中,我將集合作為一個參數 DDL 來傳遞。但是,在這里暫停一下 — 我已經分配了一個注釋作為數組的第一個單元,可能用于文檔。但它不是有效的語法。同樣,我將另一個注釋分配給數組的最后一個單元 (7),它也不是用于創建過程的有效語法。為了使包裝操作僅僅處理有效的行,我在第 13 和第 14 行中指定了存儲我們代碼的集合的最低 (2) 和最高 (6) 的單元。參數 LB 表示數組的下界,在本示例中是 2,而 HB 是上界 (6)。 
使用這種方法,現在可以從您的 PL/SQL 代碼中以打包方式創建任意大小的過程。
============================================================

CREATE OR REPLACE PROCEDURE p_wraped_user AUTHID CURRENT_USER AS
--Created by xsb on 2006-11-10 
--For:批量加密本用戶下的所有代碼,包括存儲過程、函數、包。
v_procs dbms_sql.varchar2a;

BEGIN
FOR n IN (SELECT DISTINCT NAME, TYPE
FROM user_source
WHERE NAME <> 'P_WRAPED_USER' AND
TYPE <> 'TYPE'
MINUS
SELECT DISTINCT NAME, TYPE
FROM user_source
WHERE line = 1 AND
instr(text, 'wrapped') > 0
--WHERE NAME = 'GET_CLERK' --AND
-- TYPE = 'PACKAGE BODY'
ORDER BY TYPE) LOOP
FOR i IN (SELECT rownum rn, text
FROM (SELECT decode(line, 1, 'create or replace ') || text text
FROM user_source
WHERE NAME = n.NAME AND
TYPE = n.TYPE
ORDER BY line)) LOOP
v_procs(i.rn) := i.text;
END LOOP;
dbms_ddl.create_wrapped(v_procs, 1, v_procs.COUNT);
v_procs.DELETE;
END LOOP;

END; 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产亚洲一区二区在线| 欧美剧在线观看| 日韩最新免费不卡| 亚洲高清福利视频| 91久久久久久国产精品| 日韩精品在线播放| 国产日韩在线看| 不卡av电影院| 国产日韩中文字幕| 亚洲码在线观看| 亚洲石原莉奈一区二区在线观看| 亚洲欧美综合另类中字| 亚洲电影免费在线观看| 成人福利视频在线观看| 亚洲欧美日韩一区在线| 久久99视频免费| 欧美激情中文字幕在线| 美女精品视频一区| 欧美电影在线播放| 最近2019好看的中文字幕免费| 欧美在线观看www| 亚洲另类激情图| 欧美亚洲国产另类| 国产精品丝袜高跟| 国产精品一二区| 97视频在线观看免费高清完整版在线观看| 97久久国产精品| 成人精品久久av网站| 日韩av电影在线播放| 亚洲视频在线视频| 一区二区三区四区在线观看视频| 亚洲老头同性xxxxx| 精品亚洲一区二区三区在线观看| 久久视频免费观看| 亚州国产精品久久久| 久久久久久久亚洲精品| 亚洲男人天堂2024| 俺去了亚洲欧美日韩| 欧美制服第一页| 久久激情视频免费观看| 精品日韩视频在线观看| 欧美激情xxxxx| 欧美日韩国产影院| 久久夜色精品国产亚洲aⅴ| 国产日韩欧美中文| 成人h猎奇视频网站| 国产精品久久久久久久久久久新郎| 中文.日本.精品| 国产精品com| 综合激情国产一区| 欧美激情videos| 欧美极品在线视频| 亚洲xxxxx性| 在线播放精品一区二区三区| 国产乱人伦真实精品视频| 亚洲成人精品久久| 欧美日韩国产一区二区三区| 国产精品亚洲网站| 国产精品成人一区二区| 91精品久久久久久久久中文字幕| 日韩av免费网站| 精品久久久国产| 成人午夜两性视频| 国产视频一区在线| 亚洲女人天堂色在线7777| 欧美日韩精品国产| 欧美猛男性生活免费| 亚洲jizzjizz日本少妇| 欧美激情一区二区三区在线视频观看| 日韩av电影中文字幕| 在线视频亚洲欧美| 国产精品视频免费观看www| 亚洲第五色综合网| 精品在线小视频| 在线成人中文字幕| 成人精品一区二区三区| 日韩一中文字幕| 久久久久久免费精品| 在线看国产精品| 国产ts人妖一区二区三区| 日韩av最新在线| 91热精品视频| 夜夜嗨av色一区二区不卡| 浅井舞香一区二区| 一本大道久久加勒比香蕉| 亚洲成**性毛茸茸| 国产z一区二区三区| 狠狠躁夜夜躁人人爽超碰91| 中文字幕欧美在线| 91精品国产99| 亚洲男人天堂2024| 国产91在线播放九色快色| www.日韩不卡电影av| 国产精品久久久久久亚洲调教| 中文字幕亚洲综合久久筱田步美| 波霸ol色综合久久| 91成人在线播放| 美女撒尿一区二区三区| 日韩视频―中文字幕| 国产一区二区黄| 国产欧美精品xxxx另类| 米奇精品一区二区三区在线观看| 中文字幕最新精品| 亚洲精品视频中文字幕| 久久精品亚洲一区| 91色p视频在线| 国产成人精彩在线视频九色| 欧美激情精品久久久久| 亚洲美女性生活视频| 日本韩国在线不卡| 成人免费淫片视频软件| 亚洲欧美国内爽妇网| 欧美性猛交xxxx富婆| 国模精品视频一区二区三区| 亚洲日韩第一页| 69**夜色精品国产69乱| 一本色道久久综合亚洲精品小说| 18一19gay欧美视频网站| 国产亚洲精品美女久久久| 色视频www在线播放国产成人| 久久久亚洲国产天美传媒修理工| 欧美猛交ⅹxxx乱大交视频| 欧美丰满少妇xxxxx| 国内精品久久久久久中文字幕| 欧美性猛交xxxx| 久久久久中文字幕2018| 57pao成人永久免费视频| 日韩经典一区二区三区| 日韩中文在线视频| 成人免费看吃奶视频网站| 97人人爽人人喊人人模波多| 欧美精品一本久久男人的天堂| 久久久久女教师免费一区| 欧美一级大片在线免费观看| 亚洲国产欧美在线成人app| 日韩成人激情视频| 日韩美女主播视频| 久久精品国产一区| 色偷偷88888欧美精品久久久| 在线免费观看羞羞视频一区二区| 欧美一级视频一区二区| 久久高清视频免费| 欧美激情xxxx性bbbb| 久久99精品久久久久久噜噜| 欧美日韩国产中文精品字幕自在自线| www.亚洲天堂| 久久久爽爽爽美女图片| 国产精品偷伦免费视频观看的| 日韩女在线观看| 欧美成人激情视频| 亚洲一区二区三区乱码aⅴ| 日韩最新中文字幕电影免费看| 欧美日韩国产一区中文午夜| 中文字幕日韩欧美精品在线观看| 亚洲欧美中文日韩在线| 色妞色视频一区二区三区四区| 亚洲欧美日韩一区在线| 亚洲综合小说区| 亚洲精品动漫100p| 亚洲免费av片| 亚洲欧美激情四射在线日| 亚洲а∨天堂久久精品9966| 成人性生交大片免费看小说| 成人网址在线观看|