动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Java教程 ]的信息

本月文章推荐
.Eclipse3.1中体验J2SE 5.0之枚举.
.Java抽取Word,PDF格式文件的四种.
.JavaServer Pages 3rd Edition.
.Java读取Excel方式对比.
.Java程序员面试陷阱大全.
.TOMCAT源码分析(启动框架).
.一个表达式计算案例的设计和实现.
.Java多线程程序设计入门.
.J2ME游戏开发中如何使用层的概念.
.用web_xml控制Web应用的行为(下).
.利用Java 3D技术播放动画之JMF技.
.利用正则表达式列出匹配的文件名.
.Java实现类MSN、QQ好友上线通知界.
.程序人生:Java三个月—OOP的乐趣.
.更改tomcat5.0.18的主机目录的方.
.Java Applet编程之实现显示图像.
.用JAVA转换简繁体的基础知识.
.专稿:实战EJB之五 开发实体BMP(.
.Struts+Hibernate谈J2EE的数据表.
.java 有影子的数字时钟程序.

什么是AOP系列之二:AOP与权限控制实现

发表日期:2008-1-5 |



  以往在J2EE系统中,访问权限控制系统的实现主要有两种:应用程序实现和J2EE容器实现。
  
  传统的应用程序实现
  
  这是最直接的、传统的一种解决方式,通常是在具体方法前加一个权限判定语句,如下:
  
  public class ForumFactoryProxy extends ForumFactory {
  ......
  public Forum createForum(String name, String description)
  throws UnauthorizedException, ForumAlreadyExistsException
  {
  if (permissions.get(ForumPermissions.SYSTEM_ADMIN)) {
  Forum newForum = factory.createForum(name, description);
  return new ForumProxy(newForum, authorization, permissions);
  }else {
  throw new UnauthorizedException();
  }
  }
  ......
  }
  
  上述代码是Jive论坛中一段创建论坛功能的代码,在创建论坛前,首先进行权限角色检验,假如当前用户是系统治理员,那么可以实现真正的创建。
  
  这种在具体功能前加入权限操作检验的实现方式有很多缺点:
  
  1.每个功能类都需要相应的权限检验代码,将程序功能和权限检验混淆在一起,存在紧密的耦合性,扩展修改难度大。
  
  2.假如类似Jive,以代理模式为每个功能类实现一个相应的代理类,虽然解耦了程序功能和权限检验,但是,从某个角色的权限检验这个切面考虑,涉及具体Proxy类太多,扩展修改难度大。
  
  J2EE容器实现
  
  在AOP概念没有诞生前,J2EE规范已经提供了关于权限控制的容器实现标准,这种变迁结果如下图所示:
  
  原来需要每个应用程序实现的权限Proxy转为整个容器的Proxy实现,其中JDK1.3以后的动态代理API为这种转换实现提供了技术保证。
  
  非常明显,通过容器实现权限控制验证可以大大简化应用程序的设计,分离了应用系统的权限关注,将权限控制变成了对J2EE容器服务器的配置工作。其实,容器的权限实现也是一种从一个切面来解决问题方式,AOP概念诞生后,权限控制实现由此也带来了两个方向的变化:
  
  1. J2EE容器级别的权限实现,也就是容器自身的权限实现。
  
  2. J2EE应用程序级别的权限实现。
  
  权限控制在容器级别实现似乎使得J2EE开发者感觉没有灵活性和可扩展性,其实象JBoss 4.0这样的J2EE容器,由于引入了AOP概念,使得J2EE开发者在自己的应用系统中能够直接操纵容器的一些行为。容器和应用系统由于AOP引入的ASPect切面,变得可以成为一体了。(假如使用BEA的EJBC编辑要浪费多少时间?)
  
  对于J2EE应用系统开发者,能够做到上述境界,必须的条件是对JBoss之类J2EE容器必须有足够的了解,因为这些方式并不是J2EE标准,有可能在移植到新的J2EE容器,这些知识和投入变得无用(也有可能将来J2EE扩展其标准)。
  
  很显然,使用AOP实现J2EE应用系统级别的权限控制,是解决上述移植风险的一个主要方法,但是带来的缺点是必须亲自从零开始做起,耗费时间不会很短。
  
  AOP下的应用程序权限控制实现
  
  引入AOP概念后的权限实现已经不是前面Jive实例那样“落后”,我们对这个实例进行重整(Refactorying)如下: 创建一个Aspect,专门用于权限检查
  
  private static aspect PermissionCheckAspect {
  
  private pointcut permissionCheckedExecution() :
  execution ( public Forum ForumFactory.createForum(String , String ));
  
  before () : permissionCheckedExecution() {
  if !(permissions.get(ForumPermissions.SYSTEM_ADMIN)) {
  throw new UnauthorizedException();
  }
  }
  
  }
  
  该段代码功能是:当系统运行ForumFactory.createForum方法之前,将首先检查是否有权限操作。
  
  代码中pointcut触发的条件是createForum方法执行,假如有其它需要系统治理员身份才能执行的方法加入,将写成如下代码:
  
  private pointcut permissionCheckedExecution() :
  execution ( public Forum ForumFactory.createForum(String , String )) ||
  execution ( public Forum ForumFactory.deleteForum(String , String )) ||
  ......
  execution ( public Forum ForumFactory.deleteThread(String , String ));
  
  这些方法陈列比较琐碎,依据AspectJ语法,可以简化如下:
  
  private pointcut permissionCheckedExecution() :
  execution ( public * ForumFactory .*(..));
  
  有爱好者可以将Jive论坛中相关权限Proxy部分使用AOP重整,另外,由于Jive没有引入角色概念,导致权限和用户HardCode在编码中,如何实现权限和用户解耦,最小限度的降低HardCode量,角色概念在其中起着不可忽视的重要作用。
上一篇:确保提高你的J2EE项目的质量 人气:345
下一篇:AOP系列之三:用Java动态代理实现AOP 人气:540
浏览全部Java的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-9-4 LPLY CMS 网站管理系统 v5.0
2008-9-4 缤纷互动视频交友 v3.01.902
2008-9-4 ADN视频收藏专家 v3.0 bulid 080
2008-9-4 天空网络电影系统SKYUC v2.5.6 简
2008-9-4 Web Wiz Rich Text Editor(文本编
2008-9-4 幻影动漫网视频系统(Ppdong) v1.
2008-9-4 乐维电脑在线DIY配置系统
2008-9-4 老樊文章管理系统SQL版
2008-9-4 ASP.NET 2.53 缩略图水印组件源码
2008-8-23 Mini WinMount V0.4
2008-8-23 Vista优化大师3.11正式版
2008-8-23 Wine 1.13
2008-8-23 KlipFolio 5.0 Build 5899-80
2008-8-23 Windows Sysinternals Desktops
2008-8-23 OneTap Movies1.2破解版
2008-8-23 AnnotaterPDF阅读1.1.503 破解版
2008-8-23 SoundMeter分贝测量仪 v1.0汉化破
2008-8-23 iDrum音乐节拍1.0破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | Html转换js | js/vbs加密 | md5加密 | 进制转换
实用工具:汉字翻译拼音 | 符号对照表 | 个税计算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵