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