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" "<<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)