中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > Java > 设计模式
“透明”的验证与授权 -授权与动态Proxy
作者:未知 时间:2005-07-24 21:24 出处:JR 责编:chinaitpower
              摘要:“透明”的验证与授权 -授权与动态Proxy
    这可能会被认为是“过度设计”,其实不然。我们总希望模块与模块之间的偶合性尽可能的小。好像只有几个JSP页面的应用没必要应用Struts,虽然它很优秀。这里依旧是抛砖引玉,我已经就此思路编写了部分代码,但是仍不成熟,尚存在一些疑难。最近较忙,春节期间我会把它们整理出来,希望能够为提高我们的效率做一些贡献。如果你有什么意见或建议,可以在JR的论坛里发帖子或者直接Email给我,kitta@163.com。在此先祝各位拜个早年,新年快乐,龙马精神!

                                                        -- Kitta 2004.1


在哪里执行授权行为
授权行为要么发生在Model的上层,要么发生在Model的下层。
若要授权行为对Client“透明”,则发生在下层比较容易实现。
但是这违背了SRP[#1]:Model即要完成业务逻辑,又要完成授权行为。
因此应该在Model的上层完成授权行为。

ModelFactory
但是,若在上层完成授权行为就无法使之对Client完全“透明”。
不能再使用类似Model m = new Model()的方法获得Model的实例。
至少Client要通过一个上层机制来获得,这里将这种机制暂名为ModelFactory。

动态Proxy
保护逻辑的典型做法是Proxy模式:ModelProxy继承Model,并Override某些方法,
生成完成授权行为的代码,然后将通过授权的请求委托给Model处理,
拒绝未通过的请求并以某种方式通知Client。

但是,为每一个Model创建相应的ModelProxy实际上也是一种代码的重复。
因此我们希望用一种更简洁的方式来创建ModelProxy,即动态Proxy:
Client通过ModelFactory获得Model实例时,由ModelFactory动态生成ModelProxy[并返回。
用户获得的实际上是ModelProxy的实例。

注意,这里的意思不是在Coding时由工具根据Model和配置文件生成ModelProxy的代码,
而是在运行时根据Model和配置文件生成ModelProxy的实例。

  1. Model m = ModelFactory.getModel(Model.class,crdt/*Credential*/);


如何将未经授权的访问通知系统
ModelProxy收到未经授权的访问时可以抛出一个继承java.lang.RuntimeException的异常,
这样就不会影响继承层次。
 

[#1] 单一职责原则 参见RCM《Agile Software Development》第8章
关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有