分享
 
 
 

如何利用java过程执行操作系统命令

王朝java/jsp·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

以下方法在WINNT,Linux下的Oracle9i上测试通过

首先给使用Java存储过程的用户授予一定的权限

<表示所有文件,也可以单独指定文件。

r w e d表示四种操作

Code:

Dbms_Java.Grant_Permission('HR',

'java.io.FilePermission', '<<ALL FILE',

'read ,write, execute, delete');

Dbms_Java.Grant_Permission('HR',

'java.io.FilePermission', 'd:\aa.bat',

'read ,write, execute, delete');

dbms_java.grant_permission

('HR',

'java.lang.RuntimePermission',

'*',

'writeFileDescriptor' );

end;

/

PL/SQL procedure sUCcessfully completed.

See

http://java.sun.com/j2se/1.3/doc ... timePermission.Html

http://java.sun.com/j2se/1.3/doc ... rityPermission.html

http://java.sun.com/j2se/1.3/docs/api/java/io/FilePermission.html

and

http://download-east.oracle.com/ ... 53/perf.htm#1001971

From the “Java Developer’s Guide”, Part No. A81353-01, Chapter 5:

Table 5–1 Permission Types

n java.util.PropertyPermission

n java.io.SerializablePermission

n java.io.FilePermission

n java.net.NetPermission

n java.net.SocketPermission

n java.lang.RuntimePermission

n java.lang.reflect.ReflectPermission

n java.security.SecurityPermission

n oracle.aurora.rdbms.security.PolicyTablePermission

n oracle.aurora.security.JServerPermission

相关的java类如下

SQL connect hr/hr@ts

已连接。

create or replace and compile

java source named "Util"

as

import java.io.*;

import java.lang.*;

public class Util extends Object

{

public static int RunThis(String args)

{

Runtime rt = Runtime.getRuntime();

intrc = -1;

try

{

Process p = rt.exec(args);

int bufSize = 4096;

BufferedInputStream bis =

new BufferedInputStream(p.getInputStream(), bufSize);

int len;

byte buffer[] = new byte[bufSize];

// Echo back what the program spit out

while ((len = bis.read(buffer, 0, bufSize)) != -1)

System.out.write(buffer, 0, len);

rc = p.waitFor();

}

catch (Exception e)

{

e.printStackTrace();

rc = -1;

}

finally

{

return rc;

}

}

}

/

Java created.

建立函数

create or replace

function RUN_CMD(p_cmd in varchar2) return number

as

language java

name 'Util.RunThis(java.lang.String) return integer';

/

Function created.

建立一过程调用函数

create or replace procedure RC(p_cmd in varchar2)

as

x number;

begin

x := run_cmd(p_cmd);

end;

/

Procedure created.

SQL variable x number;

SQLset serveroutput on

SQL exec dbms_java.set_output(100000);

PL/SQL procedure successfully completed.

可以执行相应的命令和bat文件

SQLexec :x := RUN_CMD('ipconfig');

windows 2000 IP Configuration

Ethernet adapter 本地连接

:

Connection-specific DNS Suffix. :

IP Address. . . . . . . . . . . . : 172.18.25.102

Subnet Mask . . . . . . .

. . . . : 255.255.255.0

Default Gateway . . . . . . . . . : 172.18.25.1

PL/SQL 过程已成功完成。

也可以执行服务器上的bat文件

SQL exec :x := RUN_CMD('c:\aa.bat');

c:\oracle\ora92\DATABASEcmd /c

c:\oracle\ora92\DATABASEdir

Volume in drive C is 本地磁盘

Volume Serial Number is 5CE1-2622

Directory of c:\oracle\ora92\DATABASE

2004-05-1515:47 <DIR.

2004-05-1515:47 <DIR..

2002-12-2420:13 <DIRarchive

1998-09-0918:31 31,744 oradba.exe

2004-05-0811:48568 OraDim.Log

2004-03-1711:531,536 PWDweblish.ora

2004-05-1515:471,871,872 SNCFWEBLISH.ORA

2003-12-2913:242,560 SPFILEWEBLISH.ORA

2004-05-0811:48 12,852 sqlnet.log

6 File(s)1,921,132 bytes

3 Dir(s) 7,141,621,760 bytes free

-----------------

c:\aa.bat如下:

cmd /c

dir

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有