自动生成代码,用官网的例子可以生成,但是自己的总是报错

Exception in thread "main" java.lang.IllegalStateException: Load propties file by invoking PropKit.use(String fileName) method first.
    at com.jfinal.kit.PropKit.getProp(PropKit.java:190)
    at com.jfinal.kit.PropKit.get(PropKit.java:200)
    at com.yunduan.news.config._JFinalGenerator.getDataSource(_JFinalGenerator.java:19)
    at com.yunduan.news.config._JFinalGenerator.main(_JFinalGenerator.java:36)

然后看了下以前有人反馈过,使用use就用ProKit.getXxx,使用load就getXxx,但是不管用这个办法,我copy的例子里面的自动生成代码,就修改了一下包名而已,给粘下自动生成代码代码吧

package com.yunduan.news.config;

import javax.sql.DataSource;
import com.jfinal.kit.PathKit;
import com.jfinal.kit.PropKit;
import com.jfinal.plugin.activerecord.dialect.MysqlDialect;
import com.jfinal.plugin.activerecord.generator.Generator;
import com.jfinal.plugin.druid.DruidPlugin;

/**
 * 本 demo 仅表达最为粗浅的 jfinal 用法,更为有价值的实用的企业级用法
 * 详见 JFinal 俱乐部: http://jfinal.com/club
 * 
 * 在数据库表有任何变动时,运行一下 main 方法,极速响应变化进行代码重构
 */
public class _JFinalGenerator {
    
    public static DataSource getDataSource() {
        DruidPlugin druidPlugin = new DruidPlugin(PropKit.get("jdbcUrl"), PropKit.get("user"), PropKit.get("password").trim());
        druidPlugin.start();
        return druidPlugin.getDataSource();
    }
    
    public static void main(String[] args) {
        // base model 所使用的包名
        String baseModelPackageName = "com.yunduan.news.entry";
        // base model 文件保存路径
        String baseModelOutputDir = PathKit.getWebRootPath() + "/src/main/java/com/yunduan/news/entry";
        
        // model 所使用的包名 (MappingKit 默认使用的包名)
        String modelPackageName = "com.yunduan.news.entry";
        // model 文件保存路径 (MappingKit 与 DataDictionary 文件默认保存路径)
        String modelOutputDir = baseModelOutputDir + "/..";
        
        // 创建生成器
        Generator generator = new Generator(getDataSource(), baseModelPackageName, baseModelOutputDir, modelPackageName, modelOutputDir);
        
        // 配置是否生成备注
        generator.setGenerateRemarks(true);
        
        // 设置数据库方言
        generator.setDialect(new MysqlDialect());
        
        // 设置是否生成链式 setter 方法
        generator.setGenerateChainSetter(false);
        
        // 添加不需要生成的表名
        generator.addExcludedTable("adv");
        
        // 设置是否在 Model 中生成 dao 对象
        generator.setGenerateDaoInModel(false);
        
        // 设置是否生成字典文件
        generator.setGenerateDataDictionary(false);
        
        // 设置需要被移除的表名前缀用于生成modelName。例如表名 "osc_user",移除前缀 "osc_"后生成的model名为 "User"而非 OscUser
        generator.setRemovedTableNamePrefixes("t_");
        
        // 生成
        generator.generate();
    }
}

然后还有个问题,那个自动类里面的_MappingKit不是生成的吗,没生成的时候这么写启动类,就找不到_MappingKit这个文件额

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


评论区

杜福忠

2019-06-27 16:36

public static DataSource getDataSource() {
这行代码,你改了啊! 官网的例子是 : DruidPlugin druidPlugin = DemoConfig.createDruidPlugin();
你这是自己 new DruidPlugin的啊.
修改一下:
把 启动类 里面那个 new DruidPlugin 抽取为一个静态 方法 createDruidPlugin(), 模仿官网例子DemoConfig里面那个写法, _JFinalGenerator 里 修改一下 DemoConfig 改为你自己的 YouConfig.createDruidPlugin();

MR.zhangzhiwei

2019-06-27 16:53

@杜福忠 6666666666666666 厉害了我的哥

MR.zhangzhiwei

2019-06-27 16:54

@杜福忠 然后还有个问题,那个自动类里面的_MappingKit不是生成的吗,没生成的时候这么写启动类,就找不到_MappingKit这个文件额

杜福忠

2019-06-27 17:15

_MappingKit 就是自己创建的啊, (生成器创建的).
https://www.jfinal.com/doc/5-2
_MappingKit只是一个很普通的Java文件, 对arp.addMapping("user", User.class);等配置的一个抽取, 之所以单独写出来一个文件, 是因为如果数据库结构有变动的时候, 运行一下生成器_JFinalGenerator, 这个文件内容就会被覆盖掉了.

"没生成的时候这么写启动类,就找不到_MappingKit这个文件" , 这不对着嘛! 普通Java里面去调用一个没有的Java类,可不报错嘛. 如果是刚入Java开发, 用JF的话, 可以网上搜索一下 "小木学堂" 看看视频讲解很细致

MR.zhangzhiwei

2019-06-27 17:25

@杜福忠 是不是先自动创建,然后才写那一行代码的,我以为不写那一行生成器自己生不出来

热门反馈

扫码入社