java 资源访问权限,限制Java中的文件访问

小编典典

使用策略文件的方法如下。

创建一个可以特权使用的Java文件:

package egPriv;

import java.io.FileReader;

import java.io.IOException;

import java.io.Reader;

import java.security.AccessController;

import java.security.PrivilegedActionException;

import java.security.PrivilegedExceptionAction;

public class PrivCat {

/** Cat a file with no privileges */

public void cat(String file) throws IOException {

cat(new FileReader(file));

}

private void cat(Reader r) throws IOException {

int c;

while( (c = r.read()) != -1 ) {

System.out.print((char) c);

}

r.close();

}

/** Cat a file WITH privileges */

public void catPriv(final String file) throws IOException {

Reader r;

try {

r = AccessController.doPrivileged(new PrivilegedExceptionAction() {

public Reader run() throws IOException {

return new FileReader(file);

}

});

} catch (PrivilegedActionException e) {

throw (IOException) e.getCause();

}

cat(r);

}

}

创建一个常规文件进行演示

package eg;

import egPriv.PrivCat;

import java.io.IOException;

public class Cat extends PrivCat {

public static void main(String[] args) throws IOException {

Cat eg2 = new Cat();

System.out.println("Processing with privilege:");

eg2.catPriv(args[0]);

System.out.println("Processing normally");

eg2.cat(args[0]);

}

}

创建sample.policy文件:

/* anyone can read write and execute within current working dir */

grant {

permission java.io.FilePermission "${user.dir}", "read,write,execute";

};

grant {

permission java.io.FilePermission "${user.dir}/*", "read,write,execute,delete";

};

/* Only code from this jar can work outside of CWD */

grant codebase "file:egPriv.jar" {

permission java.io.FilePermission "<>", "read,write,execute,delete";

};

编译然后测试:

jar cvf egPriv.jar egPriv

jar cvf eg.jar eg

echo 'Restricted' > ..\file.txt

java -cp eg.jar;egPriv.jar -Djava.security.manager -Djava.security.policy=sample.policy eg.Cat ..\file.txt

echo 'Open' > file.txt

java -cp eg.jar;egPriv.jar -Djava.security.manager -Djava.security.policy=sample.policy eg.Cat file.txt

2020-11-13

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值