JFinal开发平台搭建(2)

自动生成javabean

上篇说到创建入口类,继承JFinalConfig
我们注意到在这个类中有如下代码

public void configPlugin(Plugins me) {
        // 配置 druid 数据库连接池插件
        DruidPlugin druidPlugin = new DruidPlugin(PropKit.get("jdbcUrl"), PropKit.get("user"), PropKit.get("password"));
        me.add(druidPlugin);
        
        // ehcache插件
        EhCachePlugin ehCachePlugin = new EhCachePlugin();
        me.add(ehCachePlugin);
        
        // 配置ActiveRecord插件
        ActiveRecordPlugin arp = new ActiveRecordPlugin(druidPlugin);
        arp.setShowSql(false);
        arp.setDevMode(true);
        // 所有映射在 MappingKit 中自动化搞定
        _MappingKit.mapping(arp);
        me.add(arp);
    }

在后面配置ActiveRecord插件中,配置_MappingKit,我们看一下这个类

public class _MappingKit {
    
    public static void mapping(ActiveRecordPlugin arp) {
        
        arp.addMapping("tb_base_manager", "id",Manager.class);
        arp.addMapping("tb_base_navigation", "id",Navigation.class);
        arp.addMapping("tb_base_role","id",Role.class);
        arp.addMapping("tb_base_manager_role", "id",ManagerRole.class);
        arp.addMapping("tb_base_role_navigation","id",RoleNavigation.class);
        arp.addMapping("tb_point_record", "point_record_id",PointRecord.class);
        
    }
}

mapping方法的内部配置了表名,主键的列名,对应的实体类,当然,这些都是自动生成的,不用我们一行一行的写了

public class _JFinalDemoGenerator {
    
    public static DataSource getDataSource() {
        PropKit.use("application.properties");
        DruidPlugin druidPlugin = O2OConfig.createDruidPlugin();
        druidPlugin.start();
        return druidPlugin.getDataSource();
    }
    
    public static void main(String[] args) {
        // base model 所使用的包名
        String baseModelPackageName = "com.o2o.common.model.base";
        // base model 文件保存路径
        String baseModelOutputDir = PathKit.getWebRootPath() + "/src/main/java/com/o2o/common/model/base";
        
        // model 所使用的包名 (MappingKit 默认使用的包名)
        String modelPackageName = "com.o2o.common.model";
        // model 文件保存路径 (MappingKit 与 DataDictionary 文件默认保存路径)
        String modelOutputDir = baseModelOutputDir + "/..";
        
        // 创建生成器
        Generator generator = new Generator(getDataSource(), baseModelPackageName, baseModelOutputDir, modelPackageName, modelOutputDir);
        // 设置是否生成链式 setter 方法
        generator.setGenerateChainSetter(false);
        // 添加不需要生成的表名
        // generator.addExcludedTable("tb_shangjiaoperation1");
        // 设置是否在 Model 中生成 dao 对象
        generator.setGenerateDaoInModel(true);
        // 设置是否生成链式 setter 方法
        generator.setGenerateChainSetter(true);
        // 设置是否生成字典文件
        generator.setGenerateDataDictionary(false);
        // 设置需要被移除的表名前缀用于生成modelName。例如表名 "osc_user",移除前缀 "osc_"后生成的model名为 "User"而非 OscUser
        generator.setRemovedTableNamePrefixes("tb_base");
        // 生成
        generator.generate();
    }
}

注释中写的很清楚,可以配置哪些东西,配置完成后运行main方法,就可以自动生成javabean和映射了;

创建Controller

在创建controller之前,还是要看一下入口类的相关配置

public void configRoute(Routes me) {
        //第一个参数是访问的路径,第二个参数配置Controller,第三个参数是视图的路径
        me.add("/", IndexController.class, "/WEB-INF/view/index");
        me.add("/navigation", NavigationController.class,"/WEB-INF/view/navigation");
        me.add("/manager", ManagerController.class,"/WEB-INF/view/manager");
        me.add("/role", RoleController.class,"/WEB-INF/view/role");/
    }

我们配置了4个Controller,以后如果每增加一个controller就要在这里增加一行路由信息,以IndexController为例,编写IndexController,继承com.jfinal.core.Controller类

public class IndexController extends Controller {
    static ManagerService managerService = new ManagerService();
    
    public void index() {
        render("index.html");
    }
    
    //登陆
    public void login() throws Exception{
        ...
        redirect("/toLogin");
    }
    
    public void toLogin() {
        render("login.html");
    }
    
    public void logout() {
        ...
        redirect("toLogin");
    }
}

在访问路由中的路径时,比如(“/”),会进入到index方法中,访问其他方法需要在路由中配置的路径+方法名(“/toLogin”会访问toLogin方法),这个类展示了两种渲染方式,分别是转发(render)和重定向(redirect),此外还有renderJavascript, renderJson等其他渲染方式


至此JFinal的框架最基本的使用就配置完成了,我们可以在tomcat中运行项目或者使用以下的代码运行

public static void main(String[] args) {
        /**
         * 特别注意:Eclipse 之下建议的启动方式
         */
        JFinal.start("src/main/webapp", 8080, "/", 5);
        
        /**
         * 特别注意:IDEA 之下建议的启动方式,仅比 eclipse 之下少了最后一个参数
         */
        // JFinal.start("src/main/webapp", 80, "/");
    }

参考资料 http://www.jfinal.com/

你可能感兴趣的:(JFinal开发平台搭建(2))