首页 > 代码库 > Java急速WEB+ORM框架(JFinal)

Java急速WEB+ORM框架(JFinal)

JFinal框架是基于java语言的急速WEB+ORM框架,其设计核心是开发迅速,代码量少,学习简单,功能强大,轻量级,已扩展,Restful。在拥有java语言所有优势的同时再拥有python,php等动态语言的开发效率,让你有足够多的时间去做其他的事。

JFinal有如下主要特点:

  • MVC架构,设计精巧,使用简单

  • 遵循COC原则,零配置,无xml

  • 独创Db + Record模式,灵活便利

  • ActiveRecord支持,使数据库开发极致快速

  • 自动加载修改后的java文件,开发过程中无需重启web server

  • AOP支持,拦截器配置灵活,功能强大

  • Plugin体系结构,扩展性强

  • 多视图支持,支持FreeMarker、JSP、Velocity

  • 强大的Validator后端校验功能

  • 功能齐全,拥有struts2的绝大部分功能

  • 体积小仅218K,且无第三方依赖

JFinal官网:http://www.jfinal.com/下载需要的资料

初步实现在界面输出Hello JFinal

实现步骤:
      1.创建核心配置类,该类继承与JFinalConfig类
      2.配置xml文件
      3.创建控制器类,该类继承与Controller类
      3.将项目部署到服务器,进行测试

核心配置类:THConfig
package com.tenghu.core.config;

import com.jfinal.config.Constants;
import com.jfinal.config.Handlers;
import com.jfinal.config.Interceptors;
import com.jfinal.config.JFinalConfig;
import com.jfinal.config.Plugins;
import com.jfinal.config.Routes;
import com.tenghu.core.controller.LoginController;

public class THConfig extends JFinalConfig{

	/**
	 * 常量配置
	 */
	@Override
	public void configConstant(Constants me) {
		me.setDevMode(true);//设置开发模式
	}
	/**
	 * 配置处理器
	 */
	@Override
	public void configHandler(Handlers me) {
		
	}
	/**
	 * 配置拦截器
	 */
	@Override
	public void configInterceptor(Interceptors me) {
		
	}
	/**
	 * 配置插件
	 */
	@Override
	public void configPlugin(Plugins arg0) {
		
	}
	/**
	 * 配置路由
	 */
	@Override
	public void configRoute(Routes me) {
		me.add("/", LoginController.class);
	}
}

配置web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" 
	xmlns="http://java.sun.com/xml/ns/javaee" 
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
	http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <display-name></display-name>	
  <filter>
  	<filter-name>JFinal</filter-name>
  	<filter-class>com.jfinal.core.JFinalFilter</filter-class>
  	<init-param>
  		<param-name>configClass</param-name>
  		<param-value>com.tenghu.core.config.THConfig</param-value>
  	</init-param>
  </filter>
  <filter-mapping>
  	<filter-name>JFinal</filter-name>
  	<url-pattern>/</url-pattern>
  </filter-mapping>
</web-app>

创建控制器LoginController,该类的作用是对访问的路径进行过滤,根据配置的请求路径,进入对应的控制器,如上面再路由配置方法中配置的是“/”该路径,访问http://127.0.0.1/JFinalTest,则会进入该控制器,默认会进入index()方法中,如果控制器中有其他的方法,需要访问该方法,如其他方法为view() ,那么请求路径为http://127.0.0.1/JFinalTest/view,这里主意一点,使用工具创建的web项目,默认都会有一个index.jsp文件,如果有该文件,则访问根路径,会直接进入到index.jsp页面,所以如果需要配置为根路径,那么需要将index.jsp文件删除或移到其他目录
package com.tenghu.core.controller;
import com.jfinal.core.Controller;
/**
 * 登陆控制器
 * @author Arvin
 *
 */
public class LoginController extends Controller{
	public void index(){
		renderText("Hello JFinal");
	}
}
部署项目,如果出现Hello JFinal这句话,则表示成功

这里的这句话是直接将文本输出到界面,如果需要返回的是html页面,那么需要添加freemarker框架的jar包,使用render()方法
render("admin/index.html");
如果返回的页面是jsp页面,那么需要在核心配置类中的常量配置方法中(configConstant())中配置视图类型
/**
	 * 常量配置
	 */
	@Override
	public void configConstant(Constants me) {
		me.setDevMode(true);//设置开发模式
		me.setViewType(ViewType.JSP);//配置视图类型
	}

在控制器中返回jsp文件
render("admin/index.jsp");
如果不配置ViewType,那么jsp文件则会以静态模板显示到界面,因为JFinal框架默认的就是静态模板,所以如果要返回jsp页面,那么久需要配置视图类型

render的系列方法还有很多,比如返回JSON,File,Javascript,Html等。
简单的JFinal框架配置基本实现