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)