2017-08-15 16:13

我自己在项目中是下面这种解决方案:
try {
PropKit.use("config-product.txt");
} catch (Exception e) {
PropKit.use("config-dev.txt");
}

也就是说,优先加载生产环境配置,如果生产环境配置不存在则加载开发环境配置,我在本地开发环境中没有提供 config-produect.txt,所以始终是加载 config-dev.txt

而部署在生产环境时,会创建一个 config-product.txt 用于生产环境,原有的 config-dev.txt 被直接忽略

2017-08-15 16:09

在 YourJFinalConfig extends JFinalConfig 中添加一个方法解决一下,大致如下:
private void loadConfig() {
// 加载用于指定开发模式的配置文件
PropKit.use("application.properties");
// 读取 dev 模式
boolean dev = PropKit.getToBoolean("dev");
// 移除默认的配置文件,第一个被 use 的文件会成为默认配置文件
PropKit.useless("application.properties");
if (dev) {
PropKit.use("application-dev.properties");
} else {
PropKit.use("application-prod.properties");
}
}

然后在 configConsant(Constants me) 方法的第一行处调用一次即可,如果希望更简单,最的的四行代码可以这样:
PropKit.use(dev ? "application-dev.properties" : "application-prod.properties");

在 jfinal 之下,大概是 5 行代码可满足这个需求,但同时又不限定你的配置文件名称,少了一些约定,学习成本低

2017-08-15 11:17

标准的 maven 项目不需要改这个 default output folder,改了以后反而会出问题,把这个值改成下面的形式:
PROJECT_NAME/target/classes

前面的 PROJECT_NAME 是指你的项目实际名称,可以下载本站首页的 jfinal demo for maven 这个项目,导入到 eclipse 的时候选择 import maven project,导入以后直接就可以使用了

导入后查看项目属性,其中的 default output folder 为: jfinal_demo_for_maven/target/classes

2017-08-15 11:14

jdk 也是在不断升级的,而升级的过程中,以 sun 打头的那些 java 类可能会被删掉,例如 java 8 中就没有 sun.io.ByteToCharConverter

找一下 db2 的针对 java 8 的驱动,或许就解决了,驱动也是不断升级的

2017-08-14 22:33

对 jfinal template engine 的理解与使用已经到了非常深刻的程度,各种用法包括 layout、自定义指令、shared object 等等,并且可以将 jsp 的自定义tag 迁移过来,这种用法十分具有参考价值

感谢你的分享,不枉我花了这么多时间啊

2017-08-14 21:27

handler 搞定后,配置一下: me.add(new UrlHandler())

这种方式用得很广泛,几年前我就用这种方式做过网站的老 url 映射到新 url 的 302 重定向,将搜索引擎以前收录的 url 转到新的 url 之上

2017-08-14 21:25

@lyq027 用一个 UrlHandler 做个转换就可以了,大致如下:
1:v1、v2、... vn 当成是参数来处理
2:这类 url 通过 UrlHandler 全转换为指向 ApiController
3:转换方式为 "/api/v*/method?params" 转成 "/api/method/v*?paras
4:转换完成以后,通过 getPara(0) 即可获取到 "v1"、"v2"、..."vn" 这类参数值

转换代码可以通过正则,也可以通过简单的字符串处理代码:
public void handle(String target, req, resp, isHandled) {
if (target.startsWith("/api/v")) {
String prefix = target.substring(0, 4);
String post = target.substring(7);
String version = target.substring(5, 6);
target = prefix + post + "/" + version;
}
next.handle(target, req, resp, isHandled);
}

当然,为了简单性上面代码假定了你的版本号为 2 个字符,需要你自己调整,在此仅为示例

简单一句话,就是将 target 转换成指向正确 action 的 url 值就好

2017-08-14 19:12

v1 是指路由中的哪部分? 是否是参数,如果是 actionKey 的一部分,可以在拦截器中通过 inv.getActionKey() 整体获取

2017-08-14 19:11

cos.jar 这个包,在首页下载 jfinal-3.2-all.zip , 里面有

2017-08-14 17:38

@ThreeX 我倒是建议,直接用绝对路径:
renderTemplateToString("/path/file.html");

这类方法使用应该不多,偶尔不用 viewPath 还可以,除非你大量在用这个方法

2017-08-14 17:36

Inject 是否需要区分一下 byName 还是 byType ?

最大的问题是这句:
Object fieldValue = Class.forName(field.getType().getName()).newInstance();

如果 Field 是个接口或者抽象类,这里肯定就异常了,无法被实例化,而且这里的创建方式没有体现被实例化的“实现类”的动态特性,不如 new 出来方便

2017-08-14 17:28

最后将 ViewPathInterceptor 配置为全局拦截器就好。 如果没有使用 BaseController,可以通过 inv.getController().setAttr("viewPath", ...) 传递也可以

2017-08-14 17:27

建议用一个拦截器辅助来做一下,添加一个拦截器,并通过如下代码将 viewPath 存放在 ThreadLocal 中:
public ViewPathInterceptor implements Interceptor {
private static final ThreadLocal threadLocal = new ThreadLocal();

public void intercept(Invocation inv) {
threadLocal.set(inv.getViewPath);
try {
inv.invoke();
} finally {
threadLocal.remove();
}
}

public static String getViewPath() {
return threadLocal.get();
}
}

然后在 BaseController extends Controller 中覆盖掉原先的 renderTemplateToString 方法,先通过 ViewPathInterceot.getViewPath() 获取到 viewPath,然后再与 template 参数组合一下即可

2017-08-14 17:15

@咔嚓 在本站首页右侧下载 jfinal 手册,其中有一章内容专门讲了模板引擎的用法

2017-08-14 16:53

@昔竹 如果是 debug , 这是正常的调试信息不需要理会,否则应该是缺包, 把缺少的包找对了就搞定了