Java资源网

| JAVA基础 | 环境配置 | JDBC | 线程技术 | Socket编程 | JavaMail | JAVA与XML | 设计模式 | 技术新闻 | Java认证 | 程序人生 软件下载
| JSP&Servlet | Spring | Struts | Hibernate | JBuilder | Eclipse | WebService | EJB技术 | J2ME开发 | 应用服务器 | JXTA | Ajax
Articles search文章搜索
   关键字:
   类 别:
       
New download 最新下载
· [组件]HTML Parser 1.5
· [教程]WebSphere Studio应用教程
· [组件]JDom 1.0
· [工具]Junit3.8.1
· [教程]EJB编程及J2EE系统架构和设计
· [教程]EJB教程
· [教程]J2EE Tutorial中文版
· [教程]Java编程思想2(英文)
· [教程]java编程思想(完整版)
· [教程]Java网络编程
New articles 最新文章
· 设计移动 Web 服务
· 解析XML的时候完全忽略DTD
· 理解XML Schema XML Schema 初步
· 标签库的深入研究
· 提升JSP应用程序的七大绝招
· 如何使用JDOM对XML文件进行操作
· 处理XML字符串中特殊字符
· 利用Digester把XML转换成为Java对象
· 使用WebService 和RMI远程协作
· 使用Axis开发Web Service程序
Articles top 热门文章
· Eclipse基础--plugin插件安装(6644)
· eclipse+tomcat+lomboz的安装配置说明(4774)
· Java程序员就业前景(4584)
· Windows下JAVA环境变量的设置祥解(3788)
· Tomcat下JSP、Servlet和JavaBean环境的配置(3716)
· 使用links方式安装Eclipse插件(3698)
· 一个老程序员的心理话(3533)
· linux下jdk的安装与配置(3459)
· 初学者入门:Structs中基本配置入门(3334)
· Eclipse 运行命令行参数大全(3084)
您的位置:首页>>设计模式>>“透明”的验证与授权nbsp;-授权与动态Proxy
“透明”的验证与授权nbsp;-授权与动态Proxy
2007-04-13   来源:www.javaresearch.org  作者:未知

    这可能会被认为是“过度设计”,其实不然。我们总希望模块与模块之间的偶合性尽可能的小。好像只有几个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章


  --相关文章--
· 面向对象编程,我的思想 (2007-04-13)
· 面向对象的思维方式 (2007-04-13)
· 通过Javanbsp;Swing看透MVC设计模式 (2007-04-13)
· 适配器模式(Adapternbsp;Pattern) (2007-04-13)
· 追MM与Java的23种设计模式 (2007-04-13)
· 责任链模式(Chainnbsp;ofnbsp;Responsibility) (2007-04-13)

版权所有©2005-2006 JAVA资源网 渝ICP备05007591号 虚拟主机 | 关于我们 | 联系方式 | 广告业务 | 网站地图 | 友情链接