- 浏览: 1019720 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (529)
- 服务器 (8)
- jsp (1)
- java (6)
- AIX (1)
- solaris (3)
- linux学习 (53)
- javaScript (2)
- hibernate (1)
- 数据库 (74)
- sql语句 (8)
- oracle 学习 (75)
- oracle 案例 (42)
- oracle 管理 (42)
- Oracle RAC (27)
- oracle data guard (12)
- oracle 参数讲解 (14)
- Oracle 字符集 (8)
- oracle性能调优 (24)
- oracle备份与恢复 (12)
- oracle Tablespace (9)
- oracle性能诊断艺术 (1)
- oracle 11g学习 (5)
- oracle streams (1)
- oracle upgrade and downgrade (4)
- db2学习 (13)
- db2命令学习 (2)
- mysql (28)
- sql server (30)
- sql server 2008 (0)
- 工具 (10)
- 操作系统 (3)
- c++ (1)
- stock (1)
- 生活 (5)
- HADOOP (2)
最新评论
-
massjcy:
...
如何将ubuntu文件夹中文名改为英文 -
skypiea:
谢谢。。。
终于解决了。。。
Oracle 10.2.0.4(5)EM不能启动的解决方案(Patch 8350262) -
qwe_rt:
引用vi /etc/sysconfig/network 请问 ...
Linux操作系统下配置静态IP上网 -
liuqiang:
sudo killall -9 apache2
ps 和 kill 命令详解 -
dazuiba:
引用*绝杀 kill -9 PID 当使用此命令时,一定要通过 ...
ps 和 kill 命令详解
大家都知道oracle的很多系统包是没法看它的源码的,oracle就是将自己的源码用wrap加密了,所以看不到。为了保护自己辛苦写下的代码,我们自己也可以用该工具加密自己写的过程、函数、包、包体。只是wrap加密是不可逆的过程,所以大家在加密了自己代码的同时也必须保存好源码。下面做个wrap的小测试,我也像oracle那样只加密包体,不加密包说明,过程、函数的加密和这类似。
1、创建包说明、包体文件
包说明:d:\pkg_wrap_test .sql
create or replace package pkg_wrap_test is
--测试过程,将输入的数字以字符格式输出
procedure test1(i in number);
END pkg_wrap_test;
包体:d:\pkgbd_wrap_test .sql
create or replace package body pkg_wrap_test is
--测试过程,将输入的数字以字符格式输出
procedure test1(i in number) as
begin
dbms_output.put_line('输入参数是' || to_char(i));
end;
END pkg_wrap_test;
2、创建包说明、加密包体
SQL> create or replace package pkg_wrap_test
2 is
3 --测试过程,将输入的数字以字符格式输出
4 procedure test_wrap(i in number);
5
6 END pkg_wrap_test;
7 /
程序包已创建。
SQL> $wrap iname=d:\pkgbd_wrap_test.sql name=d:\pkgbd_wrap_test.plb
Copyright (c) 1993, 2004, Oracle. All rights reserved.
Processing d:\pkgbd_wrap_test.sql to d:\pkgbd_wrap_test.plb
3、执行创建包体的加密文件
SQL> @d:\pkgbd_wrap_test.plb;
程序包体已创建。
4、检测是否加密成功,可以通过pl/sql developer工具来检查,也可以用user_resource视图来检查。
pl/sql developer工具看的结果是:
/* Source is wrapped */
而user_resource视图的结果如下:
SQL> select name,text from user_source where type='PACKAGE BODY' and name='PKG_WRAP_TEST';
PKG_WRAP_TEST package body pkg_wrap_test wrapped
a000000
354
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
b
9f eb
CxYp585Q8j6W0BCKuJNCkFzupjkwg5m49TOf9b9cuJu/9MMWhdzQlpbyVuOWoWLRzKV0iwlp
plGpyqoX6pxQyuoCL7GPyM6lysamsq5EriREnWkPSbHKLkSAyOZJ6r+uJMo7Do8GXf12uyyr
0y+rUVvbCCJBP+Kr/LBBbjDtKWgmnbBKCtV3dxZGzsbaElc53jAnJ6MdMr6SvlTH+70CpiC/
S7IIypjYiKYahpb6
5、验证包的可用性
SQL> set serveroutput on
SQL> exec pkg_wrap_test.test_wrap(1);
输入参数是1
PL/SQL 过程已成功完成。
小测试完成
发表评论
-
sqlldr总结参数介绍
2012-06-28 14:29 22819有效的关键字: userid -- ORACLE use ... -
11gR2新特性:STANDBY_MAX_DATA_DELAY
2011-12-27 11:18 1210Active Data Guard 是 Oracle 11g ... -
Linux下用OCCI或OCI连接Oracle
2011-07-26 12:00 2898首先,去oracle官网下载C ... -
Oracle Mutex实现机制
2011-05-18 23:43 1064我们都知道Latch是Oracle ... -
local_listener参数作用
2011-05-10 17:19 1924pmon只会动态注册port等于1521的监听,否则 ... -
oracle伪列 rowid和rownum
2011-03-23 10:00 3531整理ROWID一 一,什么是伪列RowID?1,首先是一种数 ... -
Oracle10gR2 主备自动切换之客户端Failover配置
2011-01-20 10:32 9501. 主库检查和设置假设新增的服务名为ORCL_TAF.LK. ... -
Oracle10g配置Dataguard的相关参数解释
2011-01-20 10:24 1264参考自 http://space.itpub.ne ... -
利用hcheck检查数据字典一致性状态
2011-01-17 17:42 1812利用hcheck可以检查oracle数据字典的一致性状态,主要 ... -
插入相同的数据量普通表和临时表产生的redo对比
2011-01-17 16:08 985往临时表里插入相同量 ... -
Database Link与GLOBAL_NAMES参数
2011-01-12 13:36 1027当GLOBAL_NAMES参数设置为TRUE时,使用DATAB ... -
Oracle Streams学习二(清除流配置)
2011-01-09 23:34 1179在完成streams部署之后,如果需要重新配置或舍弃配置,可以 ... -
red hat enterprise 下完全删除oracle 数据库
2011-01-05 01:28 1756步骤 1 以oracle用户登录主、备节点。步骤 2 ... -
Oracle常用dump命令
2010-12-20 00:31 831Oracle常用dump命令,记录一下备查。 一.M ... -
oracle执行DML(事物过程)的深入研究(二)
2010-12-14 15:02 1535接上一节的 oracle执行DML(事物过程)的深入研究(一) ... -
oracle执行DML(事物过程)的深入研究(一)
2010-12-14 10:26 2802用户所执行 DML (即执行事务)操作在 Oracle 内部按 ... -
Oracle基本数据类型存储格式研究(二)—数字类型
2010-12-14 00:35 1471数字类型包含number,intege ... -
Oracle基本数据类型存储格式研究(一)—字符类型
2010-12-13 23:32 11701.char char是定长字符型,内部代码是:96,最多可 ... -
关于oracle rowid的一些内容 -- 转载
2010-12-13 15:47 779本文讨论的是关于oracle ... -
oracle 进制转换
2010-12-13 14:24 12571.16进制转换为10进制 ...
相关推荐
oracle db内部的package全部是加密的,需要解密使用oracle wrap加密过的程序包,而unwrap解密工具可以拿到明文的package源代码。 解密的理论依据都来源于 "The oracle hacker's handbook" by David Litchfield 这...
wrap加密方式是Oracle提供的一种数据保护方法,它使用一个密钥对其他敏感数据进行封装或“打包”。wrap技术可以保护如PL/SQL代码和数据库凭据等数据的完整性。当使用wrap技术时,可以采用一个密钥对数据进行加密,...
简介: 该软件破解了10,11g的... 使用方法: 输入用户、密码、tnsname -> 连接9i, 10g、11g数据库 -> 选择schema、代码类型 -> 选择代码->Unwrap 或者 直接将加密过的代码输入到wrap text编辑框中(仅10g、11g)->Unwrap
### 如何加密Oracle中的存储过程 #### 知识点一:理解Oracle存储过程与加密的重要性 - **存储过程概述**:存储过程是在数据库中编写的SQL程序,它们被编译并存储在数据库服务器上,可以在应用程序中通过调用执行。...
Oracle数据库中的存储过程是数据库管理员和开发者常用的工具,用于封装一系列的SQL和PL/SQL语句,以便在需要时重复调用...同时,Oracle数据库还提供了商业加密包如Oracle Advanced Security,可以提供更强的数据保护。
除了Oracle自带的WRAP工具外,市场上还有一些第三方工具提供更为高级的加密功能,如代码混淆、动态解密等。这些工具通常具有更灵活的配置选项和更强大的安全特性。 ##### 3. 使用Oracle内置功能 从Oracle 12c版本...
Oracle存储过程unwrap解密工具主要用于处理Oracle数据库中的加密存储过程。在Oracle数据库系统中,为了保护敏感代码或数据,开发人员有时会选择对存储过程进行加密。然而,当需要查看、调试或恢复这些加密的存储过程...
Oracle 提供了两种方法来加密存储过程:使用 `wrap` 工具和 `dbms_ddl` 包。 1. **wrap 工具** `wrap` 是一个操作系统级别的命令,用于加密 PL/SQL 源代码。其基本语法如下: ```bash wrap iname=input_file ...
方法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....
接下来,利用Oracle提供的`wrap`工具对存储过程进行加密。`wrap`工具位于`$ORACLE_HOME/bin`目录下,它的主要功能是将源代码加密,防止非授权用户查看。使用`wrap`工具的基本语法如下: ```bash $wrap iname=input_...
在Oracle数据库中,"wrapped"代码是指经过编译和加密的存储过程、函数或包,通常用于保护敏感的商业逻辑或源代码不被未经授权的访问。这个工具在Oracle 10g、11g和12c版本中均通过了测试,确保了广泛的兼容性,并且...
Oracle FYunwrap 是一款专为Oracle数据库设计的对象解密工具,主要功能是针对使用`wrap`命令加密的PL/SQL代码进行解密。在Oracle数据库中,`wrap`命令被用来压缩和加密源代码,以保护敏感的数据库逻辑不被轻易查看或...
在 Oracle 8i R2 中,Oracle 提供了一个名为 wrap 的工具,可以将存储过程的源代码加密。这个工具可以将源代码转换为二进制格式,使得源代码无法被直接阅读或修改。 要使用 wrap 工具,需要首先创建一个 SQL 文件,...
Oracle数据库在保护其内部资源,如存储过程、函数和包的源代码时,常常采用wrap加密技术。Wrap加密主要是为了防止未经授权的用户查看或修改这些关键的PL/SQL代码。然而,这对于数据库管理员和开发人员来说,有时需要...
为了对存储过程进行加密,可以使用Oracle提供的`wrap`工具。在命令行中执行以下命令: ```bash D:\>wrap iname=a.sql ``` 该命令将读取`a.sql`文件中的内容并生成一个名为`a.plb`的加密文件。`wrap`工具会输出类似...
加密Oracle存储过程通常涉及以下步骤: 1. **设置NLS_LANG环境变量**: 在命令行中,你需要设置NLS_LANG环境变量来确保正确的字符集。在这个例子中,有两种可能的设置: - `set NLS_LANG=AMERICAN_AMERICA.USACII...
以下是一个详细的步骤来解释如何在Windows上加密Oracle存储过程。 1. **创建存储过程** 首先,我们需要创建一个存储过程。例如,创建一个名为`test_bf`的简单存储过程: ```sql CREATE OR REPLACE PROCEDURE ...
- 使用WRAP工具进行加密。 请注意,这些知识点是基于给定文件内容的解析和补充,面试准备时还应关注更多细节和实际操作能力。在面试过程中,除了回答问题,还可能需要解释更深层次的概念、解释特定场景下的最佳...
在Oracle数据库中,开发者有时会将存储过程或函数的源代码进行加密(wrap)处理,以保护商业逻辑和敏感信息。然而,在特定情况下,如需要查看或调试已加密的代码时,就需要进行unwrap操作,即将加密的PL/SQL代码还原...