2020-05-21 16:44

语法不对,请仔细阅读文档:https://jfinal.com/doc/6-4

2020-05-21 16:43

@Clear()注解作用主要是用来清除方法上拦截器,默认不带参数默认清除所有方法上的拦截器,只想清理某一个拦截器写法:@Clear({xxx.class})即可。

2020-05-19 12:08

断点追踪下 Trans拦截器看下详细堆栈信息。

2020-05-19 12:04

查直日志,然后排查下代码看是否存在资源未释放,另外可以增加参数,-XX:-UseGCOverheadLimit,关闭这个特性,同时增加堆内存大小-Xmx1024m 试下。

2020-05-19 11:59

参考这个弄下,现货:http://www.jfinal.com/share/1024

2020-05-19 11:56

@chcode 看业务看需求任意组合,他这个反馈属于安全范畴,做全局跨域拦截器,过虑下即可。

2020-05-18 18:23

框架默认只提供GET|POST方法拦截实现,使用方式如下:
@Before({GET.class,POST.class})//表明finalAll方法只允许GET|POST请求
public void finalAll(){}

2020-05-09 10:54

@风满楼 嗯嗯!用getAttr()

2020-05-07 22:06

@你妹啊 一样的思路稍做调整,如直接把renderJson(ret)改为renderToString("HTML片段")即可,
1、后台代码:
public void index() {
var async = get("async");
var tab = getInt("tab", -1);
var stime = get("stime");
var etime = get("etime");

set("tab", tab).set("stime",stime).set("etime", etime);

var logPage = logAdminService.paginate(getPageNumber(), getPageSize(), tab, stime, etime);
var ret = Okv.by("code", 0).set("msg", "").set("count", logPage.getTotalRow()).set("data", logPage.getList());
rendertoString("_item.html", ret);
},

2、编写_html.html片段代码,例如:






#for(list: data) .....#end


3、前台调用返回html片段
$.ajax({
type: "POST",
url: "/admin/log",
data: {
tab: $("#tab").val(),
stime: $("#stime").val(),
etime: $("#etime").val()
},
dataType: "html"
success: function(ret){
$("#content").val(ret);
}
});

2020-05-07 19:34

直接用get("aa")、get(“bb”)即可拿。

2020-05-07 19:31

不知跟你的应用场景对不对个,其实这个问题很简单换个思路即可,比如场景:一个列表请求页面,页面渲染显示、拉取数据分两部走,可以在不需要类似sapringmvvc返回一个Modelandview即可实现异步请求,
1、后台代码:
public void index() {
var async = get("async");
var tab = getInt("tab", -1);
var stime = get("stime");
var etime = get("etime");

if (sl.isEmpty(async)) {
render("index.html");
return;
}

set("tab", tab).set("stime",stime).set("etime", etime);

var logPage = logAdminService.paginate(getPageNumber(), getPageSize(), tab, stime, etime);
var ret = Okv.by("code", 0).set("msg", "").set("count", logPage.getTotalRow()).set("data", logPage.getList());
renderJson(ret);
}
2、前台代码:
$.ajax({
type: "POST",
url: "/admin/log",
data: {
tab: $("#tab").val(),
async: 1,
stime: $("#stime").val(),
etime: $("#etime").val()
},
success: function(ret){
}
});
2、在请求中加一个异步参数async。
3、在第一次请求传入参数async为空表示只渲染界面显示,当async不这空则表示拉取数据,这个即可实现渲染数据、拉取数据两步头;最后拉取数据那部分页面代码是通过ajax步请求。

2020-04-11 11:48

这个问题不大很非见,就如波总上面说解答,但是你应该关系那些扫码器,探测你的系统;把安全做好,sql注入,关注业务尽量不要使用sql拼接,
1、在框架层JFinal底层基于 PreparedStatement天然支持防sql注入,在数据连接层Druid 自带有防注入功能开启即可,另外应用层如果用nginx做代理的话也可以过虑掉sql注入;
2、再次关注跨站点请求校验,xss过虑,评论提交、附件上传过虑好,系统权限控制好,在业务层再防一层;
3、最后操作系统再做层安全,只要不是ddos可以说你的安全性非常非常的高,即使存在ddos但这个也问题也大,投入更多机子然后用nginx或F5做负载分流多台机子一起扛住这波流量即可。以上是做系统防护思路,希望以你了解系统安全帮助。

2020-03-26 11:28

建议你先把问题定位出来,然后再考虑是否要升级,如果还是无法定位问题,建议你直接下载官方最新demo下来运行,在上面进行开发或学习。

2020-03-26 10:46

看官方文档说明升级说明:https://jfinal.com/doc/14-1

2020-03-26 10:44

把你地址栏访问地址贴出来,还有你的配置也一起贴出来,现在只是靠猜,这种问题,上面也已经讲得很清楚了,没有错误,模板语法原样输出,就是模板没有配置不信你直接在浏览器地址栏访问html静态页面也能打印出来来。