JessMA 是功能完备的高性能 Full-Stack Web 应用开发框架,内置可扩展的 MVC Web 基础架构和 DAO 数据库访问组件(内部已提供了 Hibernate、MyBatis 与 JDBC DAO 组件),集成了 Action 拦截、Form / Dao / Spring Bean 装配、国际化、文件上传下载和页面静态化等基础 Web 应用组件,提供高效灵活的纯 Jsp/Servlet API 编程模型,可完美整合 Spring / Guice,支持 Action Convention,能快速开发传统风格和 RESTful 风格应用程序,文档和示例完善,非常容易学习。
JessMA 官方网站:http://www.jessma.org
OSChina 项目主页:http://www.oschina.net/p/portal-basic
Github 下载地址:https://github.com/ldcsaa/JessMA
在线示例:http://demo.jessma.org
在线 API 文档:http://www.jessma.org/doc
JessMA 在设计之初就充分注重功能、性能与使用体验。JessMA 主要特点:
★ 功能全面:内置稳定高效的 MVC 基础架构和 DAO 框架,支持 Action 拦截、Form Bean / Dao Bean / Spring Bean 装配和声明式事务,提供国际化、文件上传下载、缓存和页面静态化等常用Web组件,能满足绝大部分 Web 应用的需要。
★ 高度扩展:JessMA 通过的 plug-in 机制可以灵活扩展,JessMA 发布包中自带的 jessma-ext-rest 和 jessma-ext-spring 均以插件的形式提供,用户可根据需要加载或卸载这些插件。应用程序开发者也可以根据实际需要编写自定义插件来扩展 JessMA。
★ 强大的整合能力:JessMA 是一个 Full-Stack 框架,同时也是一个开放式框架,可以以非常简单的方式整合第三方组件。本开发手册会详细阐述如何在 JessMA 中整合 Freemarker、 Velocity 、 Urlrewrite、 EHCache-Web 、 Spring 、 Hibernate 和 Mybaits 等常用框架和组件。
★ 高性能:性能要求是 JessMA 的硬性指标,从每个模块的设计到每行代码的实现都力求简洁高效。另外,Portal-Basi c并没有对 JSP/Servet API 进行过多封装,开发者仍然使用 JSP/Servet API 开发应用程序,没有过多的迂回,性能得到保证。
★ 优秀的使用体验:JessMA 的设计目标之一是提供良好的开发体验,尽量减少应用程序开发者的工作,API 的设计力求简单、完整、明确。同时,JessMA 为应用开发提供了大量 Util 工具,用来处理应用程序开发过程中通常会遇到的一般性问题,进一步减少应用程序开发者的工作负担。
★ 平缓的学习曲线:学习使用 JessMA 只需掌握一定的 Core Java 与 JSP/Servlet 知识,本开发手册会循序渐进阐述每个知识点,每个知识点都会结合完整的示例进行讲述,知识点之间前后呼应,确保学习者在学习时温故知新,融会贯通。
★ 完善的技术支持:除了提供完善的开发手册和示例代码以外,还提供博客和 QQ 群用于解答使用 JessMA 过程中碰到的所有问题,也可以访问 JessMA 官方网站了解更多资讯。
* JessMA 总体架构
JessMA主要包括以下5个部分:
● 基础应用框架
基础应用框架加载应用程序配置文件(默认:app-config.xml),监听应用程序的生命周期事件,并向上层应用发送应用程序启动和关闭通知,应用程序可以处理这些通知进行额外的初始化或清理工作。基础应用框架在org.jessma.app包中是实现。
● MVC框架
MVC框架加载MVC配置文件(默认:mvc-config.xml),通过前端控制器ActionDispatcher接收和解析所有的客户HTTP请求,然后交由相应的Action进行处理,最后生成相应的视图返回给客户端。MVC框架在org.jessma.mvc包中实现。
● DAO框架
DAO框架封装了所有的数据库访问操作,内置JDBC、Hibernate和MyBaits数据库访问组件以及Druid、Proxool、JNDI等连接池。DAO框架是可扩展的,用户可以通过扩展org.jessma.dao.AbstractFacade和org.jessma.dao.AbstractSessionMgr实现自己的数据库访问组件。DAO框架在以下包中实现:
? org.jessma.dao
? org.jessma.dao.hbn
? org.jessma.dao.jdbc
? org.jessma.dao.mybatis
● 公共组件
公共组件提供多种通用功能帮助类(如:字符串处理、类型转换、分页算法、压缩/解压、加解密、邮件发送等),这些类与框架无关,可在任何应用程序中使用。公共组件在以下包中实现:
? org.jessma.util
? org.jessma.util.archive
? org.jessma.util.http
? org.jessma.util.mail
● 扩展插件
扩展差插件是基于JessMA核心框架基础上的功能延伸,不是JessMA的必要组件。可由应用程序开发人员根据需要自行定制。JessMA发行包中也自带了一些扩展插件(如:jessma-ext-spring和jessma-ext-rest)。
基础应用框架、MVC框架和DAO框架都依赖于公共组件,其中基础应用框架同时依赖于DAO框架,因此,MVC框架和DAO框架能脱离JessMA单独使用(当然,要附带上公共组件)。例如:可以把MVC框架和DAO框架用于JessMA之外的其它Web项目;也可以把DAO框架用于非Web项目(如:Swing / SWT桌面应用)。
JessMA 3.5.1 更新:
1、JessMA 3.5.1 使用 Maven 进行构建和发布管理
1) JessMA core
<dependency> <groupId>org.jessma</groupId> <artifactId>jessma-core</artifactId> <version>3.5.1</version> </dependency>
2) JessMA RESTful 扩展
<dependency> <groupId>org.jessma</groupId> <artifactId>jessma-ext-rest</artifactId> <version>3.5.1</version> </dependency>
3) JessMA Guice 扩展
<dependency> <groupId>org.jessma</groupId> <artifactId>jessma-ext-guice</artifactId> <version>3.5.1</version> </dependency>
4) JessMA Spring 扩展
<dependency> <groupId>org.jessma</groupId> <artifactId>jessma-ext-spring</artifactId> <version>3.5.1</version> </dependency>
2、日志组件使用 slf4j 替代 Log4j
1) JessMA Logger 对象获取方式:org.jessma.util.LogUtil.getJessMALogger()
2) 其它 Logger 对象获取方式:org.jessma.util.LogUtil.getLogger()
3、其它更新
1) 依赖包更新到最新版本
2) 增加 Maven 示例工程 jessma-sample-hello 和 jessma-sample-set
3) 更新开发手册《JessMA Java Web 应用开发框架 (v3.5.1)》
JessMA 3.4.1 更新:
1、升级 Log4J 到 2.x 版本
1) Log4J 默认配置文件为 log4j2.xml
2) 默认 Logger 对象获取方式:org.jessma.util.LogUtil.getDefaultLogger(...)
3) 其它 Logger 对象获取方式:org.apache.logging.log4j.LogManager.getLogger(...)
2、其它更新
1) 依赖库 “jessma-lib” 中的所有 jar 包更新到最新版本
2) 依赖库 “spring-lib” 中的所有 jar 包更新到最新版本
3) 更新开发手册《JessMA Java Web 应用开发框架 (v3.4.1)》
JessMA 3.3.1 更新:
1、增强国际化功能
1) 支持设置应用程序器默认 Locale 和默认 Bundle
A) 如果不配置器默认 Locale 则使用系统原来的默认 Locale
B) 如果不配置默认 Bundle,则默认 Bundle 为 ‘res.application-message‘
(参考:下面的 MVC 配置文件条目)
<!--
default-locale:应用程序默认语言选项(默认:与当前操作系统一致)
default-bundle:应用程序默认 Bundle(默认:res.application-message)
-->
<i18n default-locale="en_US" default-bundle="com.bruce.res.application-message" />