亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > oracle下加密存儲過程的方法

oracle下加密存儲過程的方法

熱門標簽:百變地圖標注 語音電話機器人營銷方案 南通防封外呼系統(tǒng)運營商 修改高德地圖標注 地圖標注原件 宜賓外呼系統(tǒng)廠家 廣州市400電話辦理 淮安自動外呼系統(tǒng)開發(fā) 語音電話機器人缺點
方法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 程序單元經(jīng)常包含關(guān)于公司流程和商業(yè)秘密的非常敏感和機密的信息,這使得它們與表相類似,成為受保護的實體組。為防止未經(jīng)授權(quán)而查看源代碼的情況,我們要經(jīng)常使用 wrap 命令行實用程序,這將使程序變得很混亂。 
只有在創(chuàng)建 PL/SQL 腳本后才能調(diào)用 wrap;該實用程序?qū)⑤斎氲拿魑拇虬鼮橐粋€文件。但是,在某些情況下,您可能希望在 PL/SQL 代碼中動態(tài)生成包裝。在這種情況下,因為還不存在源文件,不能調(diào)用 wrap 實用程序。 
由于 Oracle 數(shù)據(jù)庫 10g 第 2 版提供了一個供應程序包,您可以使用它創(chuàng)建代碼,并進行打包。該程序包補充(而不是替代)了 wrap 實用程序。而后者仍然適合于希望使用命令行來快速打包大量源文件的情況。 
例如,假設(shè)您希望以打包形式創(chuàng)建簡單的過程 p1。
create or replace procedure p1 as 
begin
null; 
end;
在 PL/SQL 單元中,您可以使用以下命令以打包方式動態(tài)地創(chuàng)建這一過程:
begin
dbms_ddl.create_wrapped 
('create or replace procedure p1 as begin null; end;')
end;
/
現(xiàn)在您希望確認打包過程。您可以從字典中選擇源文本。 
SQL> select text from user_source where name = 'P1';

Text
-----------------------------------------------------------------
procedure p1 wrapped
a000000
369
abcd
abcd
……等等……
第一行 procedure p1 wrapped 是確認以打包方式創(chuàng)建過程。如果您利用 DBMS_METADATA.GET_DDL() 函數(shù)來獲取該過程的 DDL,則仍然會看到源代碼已被打包。 
有時您可能會有略微不同的需求;例如,您可能要生成 PL/SQL 代碼,但不想創(chuàng)建過程。在這種情況下,您可以將其保存在一個文件或表中,以便以后執(zhí)行。但是因為以上方法創(chuàng)建了過程,所以該方法在這里行不通。所以您需要在程序包中調(diào)用另一個函數(shù):
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 函數(shù)的輸出是一個可傳遞的參數(shù),它代表著 PL/SQL 代碼的打包輸出結(jié)果。該參數(shù)可以保存在純文件文件或表中,可以在以后執(zhí)行。如果您生成的代碼要在其他地方部署,并且必須要保證代碼的安全性,則這種方法很有用。 
如果您可以將所存儲代碼的全部文本作為一個 varchar2 數(shù)據(jù)類型(大小限制為 32K)來傳遞,則這一方法可以正常工作。如果 PL/SQL 代碼超過 32K,則您必須使用一種略微不同的方法:接受一個集合變量作為輸入。 
在這里您可以使用一個供應的數(shù)據(jù)類型:程序包 DBMS_SQL 中的 varchar2。這是一個集合數(shù)據(jù)類型 (TABLE OF VARCHAR2),表的每個單元都接收多達 32K 的文本;可隨意增加該表所含的單元數(shù),以滿足您的需要。例如,假設(shè)您必須包裝一個名為 myproc 的非常長的過程,其定義如下: 
create or replace procedure myproc as
l_key VARCHAR2(200);
begin
l_key := 'ARUPNANDA';
end;
當然,這根本不是一個非常長的過程;但是為了示范起見,假設(shè)它很長。為了將其創(chuàng)建為打包形式,您要執(zhí)行以下的 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。同樣,我在數(shù)組中只使用了 7 個單元;實際上您可能要使用若干單元來填充全部代碼。 
第 11 到第 15 行表明我如何調(diào)用該過程,以便將該過程創(chuàng)建為打包形式。在第 12 行中,我將集合作為一個參數(shù) DDL 來傳遞。但是,在這里暫停一下 — 我已經(jīng)分配了一個注釋作為數(shù)組的第一個單元,可能用于文檔。但它不是有效的語法。同樣,我將另一個注釋分配給數(shù)組的最后一個單元 (7),它也不是用于創(chuàng)建過程的有效語法。為了使包裝操作僅僅處理有效的行,我在第 13 和第 14 行中指定了存儲我們代碼的集合的最低 (2) 和最高 (6) 的單元。參數(shù) LB 表示數(shù)組的下界,在本示例中是 2,而 HB 是上界 (6)。 
使用這種方法,現(xiàn)在可以從您的 PL/SQL 代碼中以打包方式創(chuàng)建任意大小的過程。
============================================================

CREATE OR REPLACE PROCEDURE p_wraped_user AUTHID CURRENT_USER AS
--Created by xsb on 2006-11-10 
--For:批量加密本用戶下的所有代碼,包括存儲過程、函數(shù)、包。
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; 

您可能感興趣的文章:
  • Oracle 存儲過程加密方法
  • oracle 存儲過程加密的方法
  • Oracle存儲過程和存儲函數(shù)創(chuàng)建方法(詳解)
  • Oracle存儲過程及調(diào)用
  • Oracle中instr和substr存儲過程詳解
  • oracle中 procedure(存儲過程)和function(函數(shù))本質(zhì)區(qū)別
  • windows中oracle存儲過程加密的實例代碼

標簽:通化 池州 襄陽 嘉峪關(guān) 南平 南平 聊城 股票投資

巨人網(wǎng)絡通訊聲明:本文標題《oracle下加密存儲過程的方法》,本文關(guān)鍵詞  oracle,下,加密,存儲,過程,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《oracle下加密存儲過程的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于oracle下加密存儲過程的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    久久久久久久男人的天堂| 一级女性大黄生活片免费| 国产伦精品一区二区三区在线观看| a级毛片免费全部播放| 成人高清视频在线观看| 国产亚洲精品成人a在线| 一级女性全黄生活片免费| 国产a视频| 精品久久久久久中文| 天堂网中文在线| 四虎久久影院| 亚洲女人国产香蕉久久精品| 久久久成人网| 国产精品免费精品自在线观看| 午夜精品国产自在现线拍| 欧美激情一区二区三区视频| 九九精品影院| 日韩一级黄色| 欧美激情中文字幕一区二区| 欧美激情一区二区三区在线| 国产成人女人在线视频观看 | 免费毛片播放| 你懂的福利视频| 成人免费一级毛片在线播放视频| 美女免费精品视频在线观看| 日本免费乱人伦在线观看| 国产不卡福利| 二级特黄绝大片免费视频大片| 久久国产一区二区| 四虎久久影院| 免费毛片播放| 日韩一级黄色大片| 成人高清视频免费观看| 精品视频在线观看视频免费视频| 色综合久久天天综合| 日韩一级黄色大片| 99久久精品国产国产毛片| 国产综合91天堂亚洲国产| 一级毛片视频播放| 成人高清视频免费观看| 日本特黄特色aa大片免费| 精品国产一区二区三区久久久蜜臀| 国产一区二区精品在线观看| 日韩av片免费播放| 欧美a免费| 你懂的福利视频| 精品国产香蕉伊思人在线又爽又黄| 国产亚洲精品aaa大片| 成人免费网站视频ww| 精品视频在线观看免费| 精品久久久久久免费影院| 国产视频在线免费观看| 精品国产亚洲一区二区三区| 黄视频网站免费| 亚洲天堂在线播放| 成人a大片在线观看| 亚久久伊人精品青青草原2020| 中文字幕97| 成人高清护士在线播放| 国产成人精品综合在线| 国产一级强片在线观看| 四虎影视库| 尤物视频网站在线| 亚洲第一页乱| 四虎影视久久| 精品久久久久久免费影院| 精品视频在线观看一区二区三区| 可以免费在线看黄的网站| 亚洲天堂免费| 午夜欧美成人久久久久久| 99热热久久| 你懂的福利视频| 欧美另类videosbestsex视频| 免费国产在线观看| 九九久久国产精品| 日韩专区亚洲综合久久| 日韩男人天堂| 欧美大片毛片aaa免费看| 青青青草影院| 一级毛片视频播放| 久久精品免视看国产成人2021| 四虎影视精品永久免费网站 | 999久久66久6只有精品| a级毛片免费全部播放| 国产不卡在线看| 亚洲天堂免费| 欧美一级视频高清片| 欧美大片一区| 日韩中文字幕一区| 黄视频网站在线看| 欧美激情一区二区三区视频| 香蕉视频久久| 国产成人女人在线视频观看 | 亚欧视频在线| 日韩综合| 国产综合91天堂亚洲国产| 99久久精品国产麻豆| 欧美激情影院| 深夜做爰性大片中文| 成人免费网站久久久| 麻豆污视频| 成人免费福利片在线观看| 四虎影视精品永久免费网站 | 亚洲精品久久玖玖玖玖| 国产网站在线| 国产精品123| 国产不卡福利| 国产一级生活片| 欧美a级片免费看| 999久久狠狠免费精品| 国产网站免费视频| 欧美a免费| 精品国产一区二区三区精东影业 | 麻豆午夜视频| 国产韩国精品一区二区三区| 夜夜操天天爽| 91麻豆精品国产高清在线| 久草免费在线视频| 尤物视频网站在线观看| 国产麻豆精品| 亚洲 激情| 免费的黄色小视频| a级毛片免费观看网站| 999精品视频在线| 成人影院久久久久久影院| 欧美大片一区| 日日日夜夜操| 一本高清在线| 一级片片| 一 级 黄 中国色 片| 免费一级生活片| 日韩av东京社区男人的天堂| 亚欧乱色一区二区三区| 99久久精品国产麻豆| 久久精品免视看国产成人2021| 日韩一级黄色片| 国产伦久视频免费观看 视频| 国产视频一区二区在线播放| 高清一级做a爱过程不卡视频| 青青久久国产成人免费网站| 黄视频网站免费观看| 国产麻豆精品免费视频| 欧美国产日韩精品| 欧美18性精品| 欧美电影免费看大全| 日韩中文字幕一区| 999精品在线| 四虎久久影院| 国产精品1024在线永久免费| 九九精品久久| 深夜做爰性大片中文| 中文字幕97| 欧美激情中文字幕一区二区| 日韩一级黄色| 国产a视频| 亚欧成人乱码一区二区| 国产精品自拍在线观看| 四虎影视库| 国产麻豆精品| 国产成人精品综合久久久| 国产国语对白一级毛片| 国产精品免费久久| 国产成人精品综合| 国产成人女人在线视频观看| 久久国产影视免费精品| 免费国产在线观看不卡| 成人在免费观看视频国产| 欧美激情一区二区三区在线| 日韩欧美一及在线播放| 韩国毛片免费大片| 国产精品123| 国产精品免费久久| 国产91精品一区| 日韩在线观看视频黄| 可以免费在线看黄的网站| 韩国毛片| 91麻豆精品国产高清在线| 青青久在线视频| 美女免费精品高清毛片在线视 | 国产美女在线观看| 日韩欧美一及在线播放| 成人高清视频免费观看| 国产视频一区二区在线观看| 国产激情一区二区三区| 精品国产一区二区三区免费 | 精品在线观看一区| 日本特黄特色aa大片免费| 久久精品欧美一区二区| 成人免费网站视频ww| 国产视频一区在线| 亚欧成人乱码一区二区| 免费一级生活片| 韩国三级一区| 日日日夜夜操| 国产欧美精品午夜在线播放| a级毛片免费全部播放| 精品视频在线看| 黄视频网站免费观看| 亚洲第一页色| 一级毛片视频免费|