2018-02-01 10:02
想不报错 只需要在后面加个 true
getBean(Class beanClass, boolean skipConvertError)
getBean(beanClass, true)
不贴异常信息还得猜。。
看看源码:打个断点进去看看吧~
public static T injectBean(Class beanClass, HttpServletRequest request, boolean skipConvertError) {
String beanName = beanClass.getSimpleName();
return (T)injectBean(beanClass, StrKit.firstCharToLowerCase(beanName), request, skipConvertError);
}
@SuppressWarnings("unchecked")
public static final T injectBean(Class beanClass, String beanName, HttpServletRequest request, boolean skipConvertError) {
Object bean = createInstance(beanClass);
String modelNameAndDot = StrKit.notBlank(beanName) ? beanName + "." : null;
TypeConverter converter = TypeConverter.me();
Map parasMap = request.getParameterMap();
Method[] methods = beanClass.getMethods();
for (Method method : methods) {
String methodName = method.getName();
if (methodName.startsWith("set") == false || methodName.length() <= 3) { // only setter method
continue;
}
Class[] types = method.getParameterTypes();
if (types.length != 1) { // only one parameter
continue;
}
String attrName = StrKit.firstCharToLowerCase(methodName.substring(3));
String paraName = modelNameAndDot != null ? modelNameAndDot + attrName : attrName;
if (parasMap.containsKey(paraName)) {
try {
String paraValue = request.getParameter(paraName);
Object value = paraValue != null ? converter.convert(types[0], paraValue) : null;
method.invoke(bean, value);
} catch (Exception e) {
if (skipConvertError == false) {
throw new RuntimeException(e);
}
}
}
}
return (T)bean;
}
2018-01-30 18:20
@lyq027 分开执行啊,当成两步进行业务处理。
1 先使用ajax去触发“执行操作”,这时你可以使用loading效果。
2 当“执行操作”执行完毕后返回 成功或失败。
3 ajax的回调函数判断 返回结果是成功,就触发 js 的模拟表单提交进行直接下载文件
2018-01-30 16:32
社区发展很快,迎来很多刚上手的朋友, 但是根据我经常泡社区来看,很多朋友都不是很会提问啊! 这里分享一篇玉伯老师送给我们的礼物~ 希望大家都签收一下~如何向开源社区提问题使用软件产品,或多或少都会遇到问题。对于商业产品,我们可以咨询客服寻
2018-01-26 21:42
@昵称而已
好多个BaseModel ???
你指的是那种 get和set的 BaseXxxModel 吗?
这个简单啊, 让哪些BaseXxxModel 去继承你通用公共的BaseModel 就可以了。
比如我的:
public abstract class BaseAccount> extends BaseModel implements IBean {
setXxx
getXxx
}
2018-01-25 23:20
@215115704
比较简单的 递归调用函数体:
#define showMenu(me){
...html...
#@showMenu(me.menus)
...html...
}
如果你的函数体比较复杂 , 可以建一个java , 使用下面方式去调用,
通过使用addSharedObject方法,将某个具体对象添加为共享对象,可以全局进行使用,以下是代码示例:
- public void configEngine(Engine me) {
- me.addSharedObject("RESOURCE_HOST", "http://res.jfinal.com");
- me.addSharedObject("sk", new com.jfinal.kit.StrKit());
- }
以上代码中的第二行,添加了一个名为RESOURCE_HOST的共享对象,而第三行代码添加了一个名为sk的共享对象,以下是在模板中的使用例子:
- <img src="#(RESOURCE_HOST)/img/girl.jpg" />
- #if(sk.isBlank(title))
- ...
- #end
以上代码第一行中使用输出指令输出了RESOUCE_HOST这个共享变量,对于大型web应用系统,通过这种方式可以很方便地规划资源文件所在的服务器。以上第二行代码调用了名为sk这个共享变量的isBlank方法,使用方式符合开发者直觉。
注意:由于对象被全局共享,所以需要注意线程安全问题,尽量只共享常量以及无状态对象。
2018-01-25 22:35
JFinal ActiveRecord 天然支持表关联操作,并不需要学习新的东西,此为无招胜有招。表关联操作主要有两种方式:一是直接使用sql得到关联数据;二是在Model中添加获取关联数据的方法。
假定现有两张数据库表:user、blog,并且user到blog是一对多关系,blog表中使用user_id关联到user表。如下代码演示使用第一种方式得到user_name:
- public void relation() {
- String sql = "select b.*, u.user_name from blog b inner join user u on b.user_id=u.id where b.id=?";
- Blog blog = Blog.dao.findFirst(sql, 123);
- String name = blog.getStr("user_name");
- }
以下代码演示第二种方式在Blog中获取相关联的User以及在User中获取相关联的Blog:
- public class Blog extends Model<Blog>{
- public static final Blog dao = new Blog();
- public User getUser() {
- return User.dao.findById(get("user_id"));
- }
- }
- public class User extends Model<User>{
- public static final User dao = new User();
- public List<Blog> getBlogs() {
- return Blog.dao.find("select * from blog where user_id=?", get("id"));
- }
- }