Java SecurityManager checkRead()方法与示例

语法:

    public void checkRead(FileDescriptor  file_des);
    public void checkRead(String fi);
    public void checkRead(String fi , Object cntxt);

SecurityManager类checkRead()方法

  • checkRead()方法在java.lang包中可用。

  • checkRead(FileDescriptor file_des)方法使用RuntimePermission(“ readFileDescriptor”)调用checkPermission从给定的文件描述符中读取文件。

  • checkRead(String fi)方法使用RuntimePermission(fi,“ read”)调用checkPermission以从给定的fi参数读取文件。

  • 当cntxt是AccessControlContext的实例时,checkRead(String fi,Object cntxt)方法将使用FilePermission(fi,“ read”)调用checkPermission以从给定的fi参数读取文件,否则,当cntxt不是AccessControlContext的实例时,它可能会引发异常。从不同媒体读取文件时,checkRead(FileDescriptor file_des),checkRead(String fi),checkRead(String fi,Object cntxt)方法可能会引发异常。

  • checkRead(FileDescriptor file_des):

    • SecurityException-如果不允许调用线程从给定的文件描述符读取文件,则可能引发此异常。

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

  • checkRead(String fi):

    • SecurityException-如果不允许调用线程从给定的fi(file)参数读取文件,则可能引发此异常。

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

  • checkRead(String fi,Object cntxt):

    • SecurityException-如果不允许调用线程从给定的fi(文件)参数读取文件,或者cntxt(context)参数不是AccessControlContext的实例,则可能引发此异常。

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

  • 这些是非静态方法,只能通过类对象访问,如果尝试使用类名称访问这些方法,则会收到错误消息。

参数:

  • 在第一种情况下,FileDescriptor file_des-此参数表示特定于系统的文件描述符。

  • 在第二种情况下,字符串fi-此参数表示系统特定的文件名。

  • 在第三种情况下,“字符串fi,对象cntxt”

    • 字符串fi –与第二种情况中定义的相似。

    • 对象cntxt –此参数表示系统特定的安全上下文。

返回值:

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

示例

//Java程序演示示例 
//Manager的checkRead()方法的说明

import java.security.*;
import java.io.*;

public class CheckRead extends SecurityManager {
    public static void main(String[] args) {
        FileDescriptor file_desc = new FileDescriptor();
        String fi = "getProperties().doc";
        AccessControlContext cntxt = AccessController.getContext();

        //通过使用setProperty()方法是设置策略属性 
        //与安全经理
        System.setProperty("java.security.policy", "file:/C:/java.policy");

        //实例化CheckRead对象
        CheckRead cr = new CheckRead();

        //通过使用setSecurityManager()方法是设置
        //安全经理
        System.setSecurityManager(cr);

        //通过使用checkRead(FileDescriptor)方法是
        //通过使用文件描述符检查读取的文件
        cr.checkRead(file_desc);

        //通过使用checkRead(String)方法是
        //检查该读取文件 
        cr.checkRead(fi);

        //通过使用checkRead(String,cntxt)方法是
        //检查该读取文件 when cntxt is an 
        //AccessControlContext的实例
        cr.checkRead(fi, cntxt);

        //显示消息 
        System.out.println("Accepted..");
    }
}

输出结果

Exception in thread "main" java.security.AccessControlException: access denied ("java.lang.RuntimePermission" "readFileDescriptor")
	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.checkRead(SecurityManager.java:637)
	at CheckRead.main(CheckRead.java:26)