美文网首页
JFinal开发平台搭建(2)

JFinal开发平台搭建(2)

作者: 写java的逗比叫z1 | 来源:发表于2018-06-02 15:57 被阅读0次

    自动生成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)

          本文链接:https://www.haomeiwen.com/subject/zcersftx.html