oracle中java存储过程的权限设置

在oracle数据库中可以通过写java存储过程来完成许多复杂的功能,但是java存储过程在访问本地文件系统、连接网络、或者运行系统命令时,就必须为执行该过程的模式赋予相应的权限。不然执行该存储过程就会报无该操作权限的异常。

Java写的存储过程的默认权限和网页中的Applet差不多,比如不能操作文件系统、不能随便访问网络,也不能获取机器的Runtime。其实安全机制几乎是一样的,都是基于沙箱模型,加载字节码之前需要进行权限检验。

Java 2安全性的目标就是提供细粒度的访问控制、易于配置的安全策略、易于扩展的访问控制结构以及安全性扩展。OracleJVM完全符合Java 2安全性规范要求,但它的实现过程与JDK VM存在以下几点不同:

1. 与JDK不同,OracleJVM的安全性是基于定义模式的。也就是说,许可是授予定义模式的,而不是授予Java代码库。

2. 每个Java 2许可都由存储在PolicyTable中的许可对象来表示的,而且由行关键字来标识。在一个安全的、带有访问限制的模式中定义PolicyTable。(相反,JDK在一个策略文件(policy file)中保存各种许可。)你必须在PolicyTable中指定所有的安全策略,PolicyTable可以通过DBMS_JAVA包或PolicyTableManager方法来扩展和更新,如下例所示:

Call dbms_java.grant_permission(grantee, permission_type, permission_name, permission_action);

oracle.aurora.rdbms.security.PolicyTableManager.grant(grantee, permission_type, permission_name, permission_action);

参数意义:grantee代表模式表名(注意必须全为大写,如SCOTT,SYSTEM),permission_type权限类型(如java.io.FilePermisson、java.net.SocketPermission),权限名(也就是操作对象,如<<ALL FILE>>,c:/a.txt,java.sun.com:80),permission_action也就是具体的操作(如对文件的read、write,对地址端口的connect、accept)。也就ACL的权限控制方式。

3. 与JDK不同,OracleJVM支持授予和撤销或限制许可。只有JAVA_ADMIN用户(比如System用户)才能向其他用户授予访问和更新 PolicyTable的许可。OracleJVM支持所有Java 2许可以及Oracle定义的许可。另外,具有适当权限的最终用户可以定义和存储他们自己的许可。SecurityManager总是在能执行Java的会话中被初始化和激活。

OracleJVM安全性比JDK多一个模式外,其余项所表达的意义与JDK的安全模型还是一致的,也是参考着JDK的安全策略来设置的。看到上面您也应该想起了JAVA的安全策略文件的格式了吧。

下面具体讲讲实际应如何操作

例如:Java存储过程中的代码有:(假设调用下面代码的存储过程名为 JavaProcedure,在sqlplus环境下执行命令 )

            URL url = new URL("http://www.sina.com");   //访问网络
            InputStream is = url.openStream("c:/a.txt");                
   
            InputStream is = new FileInputStream();     //访问文件系统

存储过程中访问了主机www.sina.com的80端口,和文件系统,那么就必须给执行这个存储过程的模式这两个权限,否则将会出现相应的异常。

如果用户scott要执行上在存储过程中的代码,就必须以System用户给scott添加访问www.sina.com:80的和文件c:/a.txt的权限,应执行如下的命令。

1

2

3

4

5

6

7

8

9

10

11

12

1. connect system/manager@orcl;             ---- 以system身份登录到数据库

 

----调用包dbms_java中的存储过程grant_permission来对scott授权,对域名应该 resolve 的权限,

----读数据要有connect的权限,当然这里的accept可以不需要,加上也无妨。

2. call dbms_java.grant_permission('SCOTT','java.net.SocketPermission', 'www.sina.com:80', 'resolve,connect, accept');  

 

----设置scott对文件c:/a.txt有读写的权限,如果把"c:/a.txt"换成"<<ALL FILE>>",就表明拥有了对所有文件读写的权限

3.call dbms_java.grant_permission('SCOTT','java.io.FilePermission','c:/a.txt','read,write');  

 

4. connect scott/tiger@orcl;    ---- 切换回到scott模式来执行过程

 

5. call JavaProcedure;     ---- 这下用scott来执行JavaProcedure过程中的操作就没有问题了

--使用java类加载器时需进行此授权,需要读取配置文件,需要此授权
call dbms_java.grant_permission( 'scott', 'SYS:java.lang.RuntimePermission', 'getClassLoader', '')

--访问网络时需要进行此授权
call dbms_java.grant_permission( 'scott', 'SYS:java.net.SocketPermission', '消息服务器IP地址:消息port', 'connect,resolve')

--删除权限:需先收回再删除
call dbms_java.revoke_permission('scott', 'SYS:java.lang.RuntimePermission', 'getClassLoader', '*');
call dbms_java.delete_permission(key => 153); --153对应表user_java_policy.KIND列值

注:如果,出现权限问题,就把下面的脚本全部执行.

execute dbms_java.grant_permission('UJAVA','java.util.PropertyPermission','*','*');
execute dbms_java.grant_permission('UJAVA','java.io.SerializablePermission','*','*');
execute dbms_java.grant_permission('UJAVA','java.io.FilePermission','*','*');
execute dbms_java.grant_permission('UJAVA','java.net.NetPermission','*','*');
execute dbms_java.grant_permission('UJAVA','java.net.SocketPermission','*','*');
execute dbms_java.grant_permission('UJAVA','java.lang.RuntimePermission','*','*');
execute dbms_java.grant_permission('UJAVA','java.lang.reflect.ReflectPermission','*','*');
execute dbms_java.grant_permission('UJAVA','java.security.SecurityPermission','*','*');
execute dbms_java.grant_permission('UJAVA','oracle.aurora.rdbms.security.PolicyTablePermission','*','*');
execute dbms_java.grant_permission('UJAVA','oracle.aurora.security.JServerPermission','*','*');

编译无效的对象:

Select 'alter java class   "'||dbms_java.longname (object_name)||'" resolve;' from user_objects
   where object_type = 'JAVA CLASS' and status = 'INVALID';
————————————————
版权声明:本文为CSDN博主「yehangchuan11」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/yehangchuan11/article/details/8273334

注意:注意这里SCOTT要写成全大写的,否则会出现scott既不是用户也不是角色的错误。执行Java写的存储过程以后遇到提示说没有什么的权限就该分配置什么权限给操作模式。JDK有些什么权限类型、权限名、可进行的操作,以及书写格式可以参考 Permissions in the JavaTM 2 Standard Edition Development Kit (JDK)。其中有下面一些主要可能经常会用到的权限:

java.io.FilePermission

java.io.SerializablePermission

java.lang.RuntimePermission

java.net.NetPermission

java.net.SocketPermission

java.sql.SQLPermission

java.util.PropertyPermission

java.util.logging.LoggingPermission

javax.net.ssl.SSLPermission

参考文档:
        1. 保证执行Java的安全
        2. Permissions in the JavaTM 2 Standard Edition Development Kit (JDK)
        3. ORACLE技术中国用户讨论组 » Oracle常见问题集 » 如何利用java过程执行操作系统命令

加一段不大相关的到这里来:
    Oracle 8.1.6 可是一个非常经典的版本,现在还有一些项目用这个版本。Oracle 8.1.6 所带的JDK版本是1.1.7,安装之后会把注册表中的Software\JavaSoft\Java Runtime Environment\CurrentVersion键值改为1.1,这样让原来安装的JRE不能用、Java程序不能用,所以你需要把这个键值改回成正确的版号,如1.4或1.5。但Oralce还是在用它哪个老东西,所以写Java代码时记得不要用太新的API,>1.1.7的。
        
    利用企业JavaBean和CORBA,可以用Java开发多层、面向组件的应用程序;也可以用Java开发传统的数据库存储过程。Oracle8i 可以容易地把二种语言编写的应用程序组合起来。

感觉也是写得不是很清淅,如果同行朋友们看过有什么问题,请对本文进行过激的评论,谢谢!以后有空再看看用Java写的Oracle存储过程应如何处理异常。在我的示例代码中catch块都是只捕获不处理,catch(exception e){    }。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值