Proxy Design Pattern(代理模式)

本文介绍了一种使用代理模式实现文件访问权限控制的方法。通过代理类FileAccessorProxy判断用户是否有权访问特定文件,若用户无权限则拒绝访问请求。示例代码展示了普通用户与管理员角色的不同访问结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

代理模式的目标是通过代理类来隔离访问者对目标类的直接访问,访问者只能访问代理类,这样能够保证访问者对目标类的访问是受限的。

比如访问某些资源,如果访问者不具备访问的权限或条件,则代理类可以拒绝访问者的访问。这是常见实现权限的方式之一。

简单的代码可以描述该模式:

package dp.proxy;

public interface FileAccessor{
	public void readFile(String filePath);
}



package dp.proxy;

public class FileAccessorImpl implements FileAccessor {

	@Override
	public void readFile(String filePath) {
		System.out.println("读取文件操作......");
	}

}



package dp.proxy;

public class FileAccessorProxy implements FileAccessor {
	boolean accessAble = false;
	FileAccessor originalAccessor;

	public FileAccessorProxy(String userName) {
		if (userName.equals("admin")) {
			accessAble = true;
			originalAccessor = new FileAccessorImpl();
		}
	}

	@Override
	public void readFile(String filePath) {
		if (accessAble) {
			originalAccessor.readFile(filePath);
		} else {
			System.out.println("对不起,你不能访问这个文件。");
		}
	}

}



package dp.proxy;

public class Main{
	public static void main(String args[]){
		FileAccessor fileAccessor1 = new FileAccessorProxy("user");
		FileAccessor fileAccessor2 = new FileAccessorProxy("admin");
		System.out.print("普通访问者试图访问文件:     ");
		fileAccessor1.readFile("/opt/local/file");
		System.out.print("管理员试图访问文件:     "); 
		fileAccessor2.readFile("/opt/local/file");
	}
}



执行结果:

普通访问者试图访问文件:     对不起,你不能访问这个文件。
管理员试图访问文件:     读取文件操作......




转载于:https://my.oschina.net/nox/blog/488459

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值