java exec示例_Java SecurityManager checkExec()方法与示例

SecurityManager类checkExec()方法checkExec()方法在java.lang包中可用。

当给定参数拥有绝对路径时,checkExec()方法将调用带有FilePermission(commands,“ execute”)的checkPermission,否则将调用带有FilePermission(“ << ALL FILES >>”,“ execute”)的checkPermission。

checkExec()方法是一种非静态方法,只能通过类对象访问,如果尝试使用类名称访问该方法,则会收到错误消息。

在创建过程时,checkExec()方法可能会引发异常。SecurityException-如果不允许调用线程创建子进程,并且使用exec()Runtime方法为当前的安全管理器调用此异常,则可能引发此异常。

NullPointerException-如果给定参数为null,则可能引发此异常。

语法:public void checkExec(String commands);

参数:字符串命令–表示系统特定的命令。

返回值:

此方法的返回类型为void,不返回任何内容。

示例//Java程序演示示例

//void checkExec(String命令)

//SecurityManager的方法

public class CheckExec {

public static void main(String[] args) {

//通过使用setProperty()方法是设置策略属性

//与安全经理

System.setProperty("java.security.policy", "file:/C:/java.policy");

//实例化SecurityManager对象

SecurityManager smgr = new SecurityManager();

//通过使用setSecurityManager()方法是设置

//安全经理

System.setSecurityManager(smgr);

//通过使用checkExec(String命令)方法来检查

//给定命令是否可执行

smgr.checkExec("TextPad.exe");

//执行命令时显示消息

System.out.println("Command Executed..");

}

}

输出结果Exception in thread "main" java.security.AccessControlException: access denied ("java.io.FilePermission" "<>" "execute")

at java.base/java.security.AccessControlContext.checkPermission(AccessControlContext.java:472)

at java.base/java.security.AccessController.checkPermission(AccessController.java:897)

at java.base/java.lang.SecurityManager.checkPermission(SecurityManager.java:322)

at java.base/java.lang.SecurityManager.checkExec(SecurityManager.java:572)

at CheckExec.main(CheckExec.java:20)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值