初始JFinal
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了初始JFinal相关的知识,希望对你有一定的参考价值。
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
以上是关于初始JFinal的主要内容,如果未能解决你的问题,请参考以下文章