Java SecurityManager getSecurityContext() 方法



描述

Java SecurityManager getSecurityContext() 方法创建一个封装当前执行环境的对象。此方法的结果例如被三个参数的 checkConnect 方法和两个参数的 checkRead 方法使用。这些方法是必要的,因为可能需要调用受信任的方法来代表另一个方法读取文件或打开套接字。受信任的方法需要确定另一个(可能是不可信的)方法是否允许自行执行操作。此方法的默认实现是返回一个 AccessControlContext 对象。

声明

以下是java.lang.SecurityManager.getSecurityContext() 方法的声明

public Object getSecurityContext()

参数

返回值

此方法返回一个依赖于实现的对象,该对象封装了有关当前执行环境的足够信息,以便稍后执行一些安全检查。

异常

示例

我们的示例需要阻止每个命令的权限。设置了一个新的策略文件,只允许创建和设置我们的 SecurityManager。该文件位于 C:/java.policy,包含以下文本:

grant {
   permission java.lang.RuntimePermission "setSecurityManager";
   permission java.lang.RuntimePermission "createSecurityManager";
   permission java.lang.RuntimePermission "usePolicy";
};

以下示例演示了 lang.SecurityManager.getSecurityContext() 方法的用法。

package com.tutorialspoint;

public class SecurityManagerDemo {

   public static void main(String[] args) {

      // set the policy file as the system securuty policy
      System.setProperty("java.security.policy", "file:/C:/java.policy");

      // create a security manager
      SecurityManager sm = new SecurityManager();

      // set the system security manager
      System.setSecurityManager(sm);

      // get the security context
      Object con = sm.getSecurityContext();

      // print the class context
      System.out.println("" + con);
   }
}

输出

让我们编译并运行上述程序,这将产生以下结果:

Exception in thread "main" java.lang.UnsupportedOperationException: The Security Manager is deprecated and will be removed in a future release
	at java.base/java.lang.System.setSecurityManager(System.java:430)
	at com.tutorialspoint.SecurityManagerDemo.main(SecurityManagerDemo.java:14)

注意 - SecurityManager 自 17 版本起已弃用,并标记为将被移除。

java_lang_securitymanager.htm
广告