2018-07-09 17:47
@zhaofan 将 jfinal 中的那个 HashKit 工具拿过来用就可以了,里面有些工具类,所以去除了 jfinal weixin 中重复的工具
2018-07-09 17:45
调用了 dao() 方法以后,就自然变成线程安全的了,不用担心
如果没调用 dao() 方法,并且前面是 static,那么这个对象是所有线程都可以并发使用的,自然会有线程安全问题,因为内部并没有使用 synchronized 这类锁机制
如果使用的时候每次 new 出来,功能上确实是完全一样的,就是为了省点时空,仅此而已
Model 中的 dao 是不提倡这么用的,而是在 Service 中使用一个 private Xxx dao = new Xxx().dao() , 这样可以避免在业务层之外操作数据库
在首页下载一下 jfinal demo,参考里面的用法,一定要有业务层,一定不要在 model 中 new Xxx().dao() 出来,养成良好的开发习惯
2018-07-09 11:09
博主的方案非常简单,代码也很省,在 outputStream.close() 后面应该要加上一句 renderNull()
这里有个改进建议,可以将 StaticResourceController 中的代码全部转移到 FileHandler 中,request、response 对象都在里面可以直接用,最后别忘了在 if 中加两行代码:
isHandled[0] = true;
return;
加这两行一是避免 tomcat、jetty 容器处理这个请求,二是辟免执行后面的 next.handle(...)
此外,建议在 finally 块中关闭 outputStream、inputStream
最后,再建议创建一个比较小的 byte[] buffer(例如 new byte[512]),一边从 inputStream 中读,一边往 outputStream 里面写,这样就避免了每次 new 出很大的 buffer,可提升性能
在 for 循环中判断读取的 len 是不是 -1,来代替 inputStream.available();
大致结构如下:
byte[] buf = new byte[512];
int len=-1;
while((len=inputStream.read(buf)) != -1) {
outputStream.write(buf, 0, len);
}
2018-07-08 10:34
@江南1111 jfinal 的 json 模块是全开放式结构,你可以继承一下 JFinalJson,然后参考 com.jfinal.json 包下面的 JsonFactory 自建一个 MyJsonFactory ,将 json 实现切到自己实现的 json 实现上去
配置:
me.setJsonFactory(new MyJsonFactory());
扩展:
public class MyJson extends JFinalJson {
...
}
jfinal 原有的 JFinalJson 不能随便动,这个类已经用了 6 年多了,改变现有规则影响面太大
2018-07-07 22:21
@青峰大辉 用起来比 Velocity 方便多了,而且还可以用独立于 jfinal
发布的版本,不依赖于任何第三方,只有 100 多 K