Chinaunix首页 | 论坛 | 博客
  • 博客访问: 7330300
  • 博文数量: 5645
  • 博客积分: 9880
  • 博客等级: 中将
  • 技术积分: 68080
  • 用 户 组: 普通用户
  • 注册时间: 2008-04-28 13:35
文章分类

全部博文(5645)

文章存档

2008年(5645)

我的朋友

分类:

2008-04-28 21:46:46

下载本文示例代码
  今天,面向方面的程序设计(aspect-oriented programming,AOP) 框架试图在企业环境中获得立足之地。这些框架为了得到普遍采用,必须与企业系统中已经在使用的其他框架良好地集成。本文向开发人员展示了,如何将AspectWerkz AOP框架与一些现在常用的框架(如Log4J、Atlassian 性能剖析器、Hibernate和Tapestry)相集成。   本文从一个现有的Tapestry web应用程序开始。这个应用程序实现两个单独的关注点:日志记录和性能剖析。每个项目都有这些需求,许多项目用Log4J做日志记录而用Atlassian剖析器框架做性能分析。然后最初的非AOP实现被重构,以便使用AspectWerkz框架来分离每个关注点的实现。产生的应用程序代码将会更简单,更容易维护,而最重要的是,更自然,表达能力更强。   本文中描述的所有应用程序和源代码都可以下载得到。   简介   为了证明AOP的强大,我们从一个非AOP Web应用程序开始,并重构它以使用AOP。应用程序的前后映像将说明AOP是多么易于使用,及方面作为Java语言的扩展是多么有用。   示例程序实现了一个示例blog,以允许用户在已有文章上张贴新的文章和评论。它是由多种框架实现的,包括用于web层的Tapestry,作为O/R Mapping解决方案的Hibernate,以及把各部分结合起来的Sping框架。日志记录是用Log4J框架实现的,而性能是用Atlassian剖析器来监控的。   出于演示目的,blog应用程序保持尽可能地简单。尽管很简单,blog应用程序包含了使它像一个“真正的”应用程序的足够功能,因此文中的代码可以应用于现有的企业项目。   本文假定读者对AOP概念有基本的理解。AOP的初学者应该阅读下面引用的文章和教程。所有的例子都将用运行在BEA WebLogic JRockit 1.4.2 SDK上的AspectWerk 2.0实现。另外一些可选的环境请参见AspectWerk主站点。   运行示例程序   要运行示例应用程序,需要一个数据库和一个servlet容器。本文假定使用MySQL。   安装完必需的软件后,下载并解压示例代码到一个临时目录中。该发行版中有三个文件: blog-ddl.sql blog-preaop.war blog-postaop.war   首先,设置MySQL来得到所需的数据库。把数据库命名为“blog”,并设置一个口令为“password”的用户id“blog”。然后通过执行blog-ddl.sql脚本来定义模式(在MySQL提示符下键入sourceblog-ddl.sql)。   现在我们可以部署应用程序了。Blog应用程序的两个版本都被打包成WAR文件,所以可以直接了当地部署到servlet容器中。   现在可以通过访问网址http://localhost:7001/blog-preaop/blog和http://localhost:7001/blog-postaop/blog来运行应用程序了。试着运行应用程序的一些功能并检查WEB-INF/classes目录中的源代码。本文的其余部分将详细分析两种实现并着重说明AOP方法的优点。   分析最初的blog应用程序   blog应用程序实现了两个横切关注点:日志记录和性能剖析。这些关注点要在贯穿整个应用程序的所有类中实现。让我们看看,利用AOP出现以前可用的标准Java工具是如何实现这两个关注点的。   日志记录  日志记录的目的是能够在不打开调试器的情况下调试生产应用程序。在我的项目中已经证明很有价值的有,通过记录每个方法的入口和出口来跟踪代码。例如,在HibernateEntryDao类中,下面的代码是用来查找所有blog入口的: private static final Log log = Log.getLog(EntryHibernateDao.class); public Entry[] findAll() { log.enter("findAll"); List entries = getHibernateTemplate().find("from Entry"); log.exit("findAll"); return (Entry[])entries.toArray(new Entry[] {}); }   当用于整个代码时,将对完全的用户请求产生下面的日志输出:com.tss.blog.web.ApplicationServlet INFO : >service: ’/blog’ com.tss.blog.service.BlogSvcImpl INFO : >findAllEntries com.tss.blog.persistence.EntryHibernateDao INFO : >findAll com.tss.blog.persistence.EntryHibernateDao INFO :   今天,面向方面的程序设计(aspect-oriented programming,AOP) 框架试图在企业环境中获得立足之地。这些框架为了得到普遍采用,必须与企业系统中已经在使用的其他框架良好地集成。本文向开发人员展示了,如何将AspectWerkz AOP框架与一些现在常用的框架(如Log4J、Atlassian 性能剖析器、Hibernate和Tapestry)相集成。   本文从一个现有的Tapestry web应用程序开始。这个应用程序实现两个单独的关注点:日志记录和性能剖析。每个项目都有这些需求,许多项目用Log4J做日志记录而用Atlassian剖析器框架做性能分析。然后最初的非AOP实现被重构,以便使用AspectWerkz框架来分离每个关注点的实现。产生的应用程序代码将会更简单,更容易维护,而最重要的是,更自然,表达能力更强。   本文中描述的所有应用程序和源代码都可以下载得到。   简介   为了证明AOP的强大,我们从一个非AOP Web应用程序开始,并重构它以使用AOP。应用程序的前后映像将说明AOP是多么易于使用,及方面作为Java语言的扩展是多么有用。   示例程序实现了一个示例blog,以允许用户在已有文章上张贴新的文章和评论。它是由多种框架实现的,包括用于web层的Tapestry,作为O/R Mapping解决方案的Hibernate,以及把各部分结合起来的Sping框架。日志记录是用Log4J框架实现的,而性能是用Atlassian剖析器来监控的。   出于演示目的,blog应用程序保持尽可能地简单。尽管很简单,blog应用程序包含了使它像一个“真正的”应用程序的足够功能,因此文中的代码可以应用于现有的企业项目。   本文假定读者对AOP概念有基本的理解。AOP的初学者应该阅读下面引用的文章和教程。所有的例子都将用运行在BEA WebLogic JRockit 1.4.2 SDK上的AspectWerk 2.0实现。另外一些可选的环境请参见AspectWerk主站点。   运行示例程序   要运行示例应用程序,需要一个数据库和一个servlet容器。本文假定使用MySQL。   安装完必需的软件后,下载并解压示例代码到一个临时目录中。该发行版中有三个文件: blog-ddl.sql blog-preaop.war blog-postaop.war   首先,设置MySQL来得到所需的数据库。把数据库命名为“blog”,并设置一个口令为“password”的用户id“blog”。然后通过执行blog-ddl.sql脚本来定义模式(在MySQL提示符下键入sourceblog-ddl.sql)。   现在我们可以部署应用程序了。Blog应用程序的两个版本都被打包成WAR文件,所以可以直接了当地部署到servlet容器中。   现在可以通过访问网址http://localhost:7001/blog-preaop/blog和http://localhost:7001/blog-postaop/blog来运行应用程序了。试着运行应用程序的一些功能并检查WEB-INF/classes目录中的源代码。本文的其余部分将详细分析两种实现并着重说明AOP方法的优点。   分析最初的blog应用程序   blog应用程序实现了两个横切关注点:日志记录和性能剖析。这些关注点要在贯穿整个应用程序的所有类中实现。让我们看看,利用AOP出现以前可用的标准Java工具是如何实现这两个关注点的。   日志记录  日志记录的目的是能够在不打开调试器的情况下调试生产应用程序。在我的项目中已经证明很有价值的有,通过记录每个方法的入口和出口来跟踪代码。例如,在HibernateEntryDao类中,下面的代码是用来查找所有blog入口的: private static final Log log = Log.getLog(EntryHibernateDao.class); public Entry[] findAll() { log.enter("findAll"); List entries = getHibernateTemplate().find("from Entry"); log.exit("findAll"); return (Entry[])entries.toArray(new Entry[] {}); }   当用于整个代码时,将对完全的用户请求产生下面的日志输出:com.tss.blog.web.ApplicationServlet INFO : >service: ’/blog’ com.tss.blog.service.BlogSvcImpl INFO : >findAllEntries com.tss.blog.persistence.EntryHibernateDao INFO : >findAll com.tss.blog.persistence.EntryHibernateDao INFO : 下载本文示例代码


Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门Aspectwerkz 2.0开发企业AOP快速入门
阅读(174) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~