Wrap方式加密安全
Wrap的限制:app
1.此方法对加密相似密码的东西,不是很安全。函数
2.加密后的文件对于通常人来讲,是比较安全的,可是对于专业人士来讲,也是形同虚设的。加密
3.不能加密触发器。spa
4.加密的过程当中,是不会检查你的语法错误的,只是在编译的时候会检查。code
5.他是向上兼容的,依赖于Oracle的版本,好比是8.1.5的加密文件,能够在8.1.6的版本上跑,可是blog
8.1.6版本的Oracle加密文件,在8.1.5上不必定能跑。io
6.只能加密以下类型,不能加密匿名块编译
CREATE [OR REPLACE] FUNCTION function_name CREATE [OR REPLACE] PROCEDURE procedure_name CREATE [OR REPLACE] PACKAGE package_name CREATE [OR REPLACE] PACKAGE BODY package_name CREATE [OR REPLACE] TYPE type_name AS OBJECT CREATE [OR REPLACE] TYPE type_name UNDER type_name CREATE [OR REPLACE] TYPE BODY type_name
DBMS_DDL包含了加密存储过程,函数,类型说明,类型体,包说明,包体,此子程序提供了动态生成PLSQL单元的能力。其实内部就是一个WRAP函数和一个CREATE_WRAPPED存储过程。再加上一个异常处理的单元MALFORMED_WRAP_INPUT。function
固然调用DBMS_DDL.CREATE_WRAPPED的时候必须保证你的本地没有生命这样的存储过程,或者你在调用的时候要加上SYS.DBMS_DDL
.WRAP
or SYS.DBMS_DDL
.CREATE_WRAPPED,这个时候就得有执行这两个存储过程的权限了。
DECLARE package_text VARCHAR2(32767); -- text for creating package spec & body FUNCTION generate_spec (pkgname VARCHAR2) RETURN VARCHAR2 AS BEGIN RETURN 'CREATE PACKAGE ' || pkgname || ' AS PROCEDURE raise_salary (emp_id NUMBER, amount NUMBER); PROCEDURE fire_employee (emp_id NUMBER); END ' || pkgname || ';'; END generate_spec; FUNCTION generate_body (pkgname VARCHAR2) RETURN VARCHAR2 AS BEGIN RETURN 'CREATE PACKAGE BODY ' || pkgname || ' AS PROCEDURE raise_salary (emp_id NUMBER, amount NUMBER) IS BEGIN UPDATE employees SET salary = salary + amount WHERE employee_id = emp_id; END raise_salary; PROCEDURE fire_employee (emp_id NUMBER) IS BEGIN DELETE FROM employees WHERE employee_id = emp_id; END fire_employee; END ' || pkgname || ';'; END generate_body; BEGIN -- Generate package spec package_text := generate_spec('emp_actions') -- Create wrapped package spec DBMS_DDL.CREATE_WRAPPED(package_text); -- Generate package body package_text := generate_body('emp_actions'); -- Create wrapped package body DBMS_DDL.CREATE_WRAPPED(package_text); END; /
值得注意的是当你调用DBMS_SQL
.PARSE这个函数去解析
DBMS_DDL
.WRAP这个加密的结果的时候,传入的文本超多了32767 bytes,你就必须设置
LFFLG为FALSE,不然DBMS_SQL
.PARSE这个解析的结果将是混乱的