Java SecurityManager checkExec()方法与示例
SecurityManager类checkExec()
方法
checkExec()方法在java.lang包中可用。
当给定参数拥有绝对路径时,checkExec()方法将调用带有FilePermission(commands,“execute”)的checkPermission,否则将调用带有FilePermission(“<<ALLFILES>>”,“execute”)的checkPermission。
checkExec()方法是一种非静态方法,只能通过类对象访问,如果尝试使用类名称访问该方法,则会收到错误消息。
在创建过程时,checkExec()方法可能会引发异常。
SecurityException-如果不允许调用线程创建子进程,并且使用exec()
Runtime方法为当前的安全管理器调用此异常,则可能引发此异常。
NullPointerException-如果给定参数为null,则可能引发此异常。
语法:
public void checkExec(String commands);
参数:
字符串命令–表示系统特定的命令。
返回值:
此方法的返回类型为void,不返回任何内容。
示例
//Java程序演示示例 //voidcheckExec(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" "<<ALL FILES>>" "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)