2020-05-08 17:40

单步跟踪一下,看是哪里取不到,或许是参数不对

2020-05-08 17:39

@tctc4869 "不该自己处理" 的意思如下:
1:假定你老项目处理的请求的 url 格式为 /xxx/...
2:假定你让 jfinal 整合后处理的请求的 url 格式为 /yyy/...
3:在 web.xml 中先配置 JFinalFilter,后配置 spring 的 filter 或 servlet,那么请求会先到达 jfinal

那么,jfinal 的 JFinalFilter 会最先接管所有请求:
1:/xxx/... 这种原本该老项目处理的 url 也会被 jfinal 接管
2:接管以后,如果不 "放行" 的话,默认会返回 404 错误

所以,你需要用一个 jfinal 的 Handler 来跳过这些 "不该自己处理" 的 url 请求,handler 内部结构大致如下:
public MyHandler extends Handler {
public void handle(String target, HttpServletRequest req, HttpServletResponse resp,boolean[] isHandled) {
if (target.starts("/xxx/") {
// 这里要放行给 spring
return ;
} else {
next.handle(target, req, resp, isHandled);
}
}

最后配置一下这个 handler
me.add(new MyHandler());

更多 handler 的例子参考:
com.jfinal.ext.handler 包中的源码

2020-05-08 17:32

@LJL2020 com.jfinal.plugin.activerecord.DbPro

2020-05-08 17:32

record 对象中放入 id 值,例如:
record.set("id", xxx);
Db.update("表名", id, record);

2020-05-08 17:31

NullPointerException 是最容易排除的,单步调试一下,找到为 null 的对象即可

2020-05-08 17:30

@祥子 这个通过扩展 MetaBuilder 也一样可以实现的, jfinal 只实现了最常用的场景,通常都是大部分 table 需要重成,少部分使用 addExcludedTable 来排除

此外,即便你是新增表,也可以老表、新表一起生成,只会覆盖 Base Model 等类文件,十分安全

老表、新表一起生成还有个好处,在老表结构改变以后,重新生成是强需求,否则很难办

2020-05-08 17:27

向 Model 中 put 的时候,可以直接 put List 进去,而不必循环进行 put

FastJsonFactory 是通过 getter 方法进行转换的,针对 Model 转换可以用生成器生成 getter 方法

join 查询出来的数据,目前只能通过 JFinalJsonFactory 来转换

我觉得你可以选取一个最常用的场景,例如 JFinalJsonFactory 被选取。 在最常用场景之上,可以临时使用其它 json 转换,例如:
String jsonString = FastJson.getJson().toJson(...);
renderJson(jsonString);

以上两行代码,就是在临时使用 FastJson 实现进行转换

2020-05-08 11:57

代码十分简洁,赞

2020-05-08 11:14

刚提到 jfinal 是独创的 "API 引导式" 配置, 所以,你再回看整个 jfinal ,没有一个地方是直接依赖于外部配置文件的,都是 setter 方法进行配置

2020-05-08 11:13

jfinal 的配置属于独创的 "API 引导式" 配置,目的是为了让你避免自己去记忆各种配置名称,因为 API 引导方式可以让 eclipse 自动提示你配置的名称(方法名的代码提示),还可以在 API 上通过注释告诉你配置的各种用法,免去学习成本

但有些配置必须要外部化,不能写在 java 代码中,因为可能需要常常去修改,所以 PropKit 就建立了配置文件与 API 引导式配置的桥梁

2020-05-08 11:10

undertow 为嵌入式而生,应该是不支持配置文件方式来配置 Listener 等东西的

但你可以通过 jfinal undertow 提供的 PropExt 或者 jfinal 自带的 PropKit + Prop 来读配置文件,然后在 java 代码中使用

你还可以自已写读取 xml 的工具类来读 web.xml 让 undertow 使用

就好比 jfinal 借助 PropKit + Prop,可以使得配置文件可以在 YourJFinalConfig 中使用是一个道理

2020-05-08 10:53

jfinal 是标准的 java web 项目,所以,只需要在 web.xml 中添加 JFinalFilter 就可以将 jfinal 集成到原有的 java web 项目中去了

不想改成 maven,可以在首页右侧下载 jfinal-4.8-all.zip ,里头有相应的 jar 包可以放到项目中使用

通过在 web.xml 中引入 jfinal, 相当于你现有的项目与 jfinal 是共存的,新功能就可以直接做到 jfinal 中去了,两头互不干扰

有一个问题需要注意,web.xml 中配置的 JFinalFilter 与其它的 Filter 在调用时有先后次序,先配置的先调用

所以,如果配置在前面的 Filter 要注意将 "不该自己处理" 的请求 "放行", 否则后续的 Filter 收不到请求

2020-05-08 10:46

补充一下,上例中用到的 filter 方法,只是演示了一种用法,你还可以通过正则表达式等其它方法决定其行为,只要是返回值为 true ,其 table 将会被过滤掉

2020-05-08 10:45

MetaBuilder 中留了两个扩展的地方,一个是 isSkipTable(String tableName) ,另一个是 filter(Predicate predicate)

其中前一个需要继承 MetaBuilder 来扩展,这个是在 JDK 8 之前给定的扩展方式

后来 jfinal 要求至少 JDK 8 以后,留了 filter 这第二个扩展,扩展方式在源码的注释里头有:
Generator gen = new Generator(...);
gen.setMetaBuilder(new MetaBuilder(dataSource).filter(
tableName -> {
return tableName.startsWith("SYS_");
})
);
gen.addExcludedTable("error_log"); // 注意这行代码要放在上面的之后调用
gen.generate();

上面的例子中,排除掉了以 "SYS_" 打头的 table,应该正好是你需要的使用方法

jfinal 其实处处可扩展,建议有时间的时候稍微浏览一下源代码,必然会轻松增加很多新技能

2020-05-07 20:46

第一次会将依赖下载到本地库,这个过程会比较慢,一般建议将 maven 配置指向阿里云的 maven 库

第一次下载完成以后,后面无需下载