java check方法,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)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值