JFinal 是基于 Java 语言的极速 WEB + ORM 开发框架,其核心设计目标是开发迅速、代码量少、学习简单、功能强大、轻量级、易扩展、Restful。在拥有Java 语言所有优势的同时再拥有 ruby、python、php 等动态语言的开发效率!为您节约更多时间,去陪恋人、家人和朋友!
在我还没有认识JFinal的理论知识前,我新建的第一个JFinalDemo项目,我的第一次感觉是:太简单了,太随意了!哈哈,我是debug模式下启动他的,然后我可以直接在Java代码中随意的修改,然后页面刷新,效果直接显现出来!这就叫“热编译”。其次,个人还总结了JFinal的其他主要特点:
? MVC 架构,设计精巧,使用简单
? 遵循 COC 原则,零配置,无 xml
? 独创 Db + Record 模式,灵活便利
? ActiveRecord 支持,使数据库开发极致快速
? 自动加载修改后的 java 文件,开发过程中无需重启 web server
? AOP 支持,拦截器配置灵活,功能强大
? Plugin 体系结构,扩展性强
? 多视图支持,支持 FreeMarker、JSP、Velocity
? 强大的 Validator 后端校验功能
? 功能齐全,拥有 struts2 绝大部分核心功能
? 体积小仅 218K,且无第三方依赖
JFinal 遵循大道至简的设计思想。主要创新点:
- 微内核+全方位扩展架构;
- Db + Record 模式;
- CPI模式;
- ActiveRecord模式Java实现方式;
- API引导式配置;
- API引导Validate;
- 采用Scanner + ClassLoader结合Jetty实现热加载;
- 极简设计,核心代码约2000行实现Web MVC + ORM。
JFinal的架构及原理
JFinal采用微内核全方位扩展架构,全方位是指其扩展方式在空间上的表现形式。
JFinal由Handler、Interceptor、Controller、Render、Plugin五大部分组成,以Action为参照,Handler处在扩展的最外围,Interceptor处在更贴近Action的周围,Controller承载Action处在扩展的中心,Render处于Action后端,Plugin处于在Action侧边位置。
JFinal实现极速开发主要是因为走的极简设计风格:零配置、代码量少、开发体验连续、无第三方依赖、概念最少化等等。
要实现极简设计,必须要为架构注入灵魂,系统才有自己的极简性格。设计前先在脑海中形成一整套的极简设计思想,让这套思想融入到灵魂的深处,在行动时每动一个设计念头时以此为指导思想,最后的结果就能如愿。
关于JFinal的介绍就不多说了,使用JFinal框架的人也越来越多了,关于它的介绍也很多。
下面是JFinal事务处理原理:
声明式事务处理原理
上述配置中为 savePost() 配置了事务也就是拦截器 Tx,当调用到 savePost() 的时候,是会进入到 Tx 的 intercept 方法中的:
- 建立数据库连接;
- 设置事务隔离级别;
- 设置事务手动提交;
- 反射机制调用 savePost();
- 事务提交;
- 若事务失败,就回滚。
主要代码如下:
public void intercept(Invocation inv) { Config config = getConfigWithTxConfig(inv); if (config == null) config = DbKit.getConfig(); Connection conn = config.getThreadLocalConnection(); // 下面这段支持嵌套事务,可以忽略不看 if (conn != null) { try { if (conn.getTransactionIsolation() < getTransactionLevel(config)) conn.setTransactionIsolation(getTransactionLevel(config)); inv.invoke(); return ; } catch (SQLException e) { throw new ActiveRecordException(e); } } Boolean autoCommit = null; try { // 1. 建立数据库连接 conn = config.getConnection(); autoCommit = conn.getAutoCommit(); config.setThreadLocalConnection(conn); // 2. 设置事务隔离级别 conn.setTransactionIsolation(getTransactionLevel(config)); // conn.setTransactionIsolation(transactionLevel); // 3. 设置事务手动提交 conn.setAutoCommit(false); // 4. 反射机制调用 savePost() inv.invoke(); // 5. 事务提交 conn.commit(); } catch (NestedTransactionHelpException e) { if (conn != null) try {conn.rollback();} catch (Exception e1) {LogKit.error(e1.getMessage(), e1);} LogKit.logNothing(e); } catch (Throwable t) { // 6. 若有异常就回滚 if (conn != null) try {conn.rollback();} catch (Exception e1) {LogKit.error(e1.getMessage(), e1);} throw t instanceof RuntimeException ? (RuntimeException)t : new ActiveRecordException(t); } finally { try { if (conn != null) { if (autoCommit != null) conn.setAutoCommit(autoCommit); conn.close(); } } catch (Throwable t) { LogKit.error(t.getMessage(), t); // can not throw exception here, otherwise the more important exception in previous catch block can not be thrown } finally { config.removeThreadLocalConnection(); // prevent memory leak } } }
JFinal官网:http://www.jfinal.com