JFinal的renderJson在处理Enum的问题

林林悦之 发布于 2013/04/20 11:54
阅读 2K+
收藏 1

@JFinal 你好,非常感谢你的框架,这让我在工作中省了不少事。

我的类中有Enum字段,在调用renderJson()函数时会报错,如下:

[ERROR]-[Thread: qtp1007764900-19]-[com.jfinal.core.ActionHandler.handle()]: /car/all
java.lang.RuntimeException: Class com.jfinal.kit.JsonKit can not access a member of class sun.misc.Launcher$ExtClassLoader with modifiers "public static"
	at com.jfinal.kit.JsonKit.beanToJson(JsonKit.java:248)
	at com.jfinal.kit.JsonKit.otherToJson(JsonKit.java:230)
	at com.jfinal.kit.JsonKit.toJson(JsonKit.java:202)
	at com.jfinal.kit.JsonKit.toKeyValue(JsonKit.java:74)
	at com.jfinal.kit.JsonKit.mapToJson(JsonKit.java:60)
	at com.jfinal.kit.JsonKit.beanToJson(JsonKit.java:269)
	at com.jfinal.kit.JsonKit.otherToJson(JsonKit.java:230)
	at com.jfinal.kit.JsonKit.toJson(JsonKit.java:202)
	at com.jfinal.kit.JsonKit.toKeyValue(JsonKit.java:74)
	at com.jfinal.kit.JsonKit.mapToJson(JsonKit.java:60)
	at com.jfinal.kit.JsonKit.beanToJson(JsonKit.java:269)
	at com.jfinal.kit.JsonKit.otherToJson(JsonKit.java:230)
	at com.jfinal.kit.JsonKit.toJson(JsonKit.java:202)
	at com.jfinal.kit.JsonKit.toKeyValue(JsonKit.java:74)
	at com.jfinal.kit.JsonKit.mapToJson(JsonKit.java:60)
	at com.jfinal.kit.JsonKit.beanToJson(JsonKit.java:269)
	at com.jfinal.kit.JsonKit.otherToJson(JsonKit.java:230)
	at com.jfinal.kit.JsonKit.toJson(JsonKit.java:202)
	at com.jfinal.kit.JsonKit.toKeyValue(JsonKit.java:74)
	at com.jfinal.kit.JsonKit.mapToJson(JsonKit.java:60)
	at com.jfinal.kit.JsonKit.beanToJson(JsonKit.java:269)
	at com.jfinal.kit.JsonKit.otherToJson(JsonKit.java:230)
	at com.jfinal.kit.JsonKit.toJson(JsonKit.java:202)
	at com.jfinal.kit.JsonKit.toKeyValue(JsonKit.java:74)
	at com.jfinal.kit.JsonKit.mapToJson(JsonKit.java:60)
	at com.jfinal.kit.JsonKit.beanToJson(JsonKit.java:269)
	at com.jfinal.kit.JsonKit.otherToJson(JsonKit.java:230)
	at com.jfinal.kit.JsonKit.toJson(JsonKit.java:202)
	at com.jfinal.kit.JsonKit.toKeyValue(JsonKit.java:74)
	at com.jfinal.kit.JsonKit.mapToJson(JsonKit.java:60)
	at com.jfinal.kit.JsonKit.beanToJson(JsonKit.java:269)
	at com.jfinal.kit.JsonKit.otherToJson(JsonKit.java:230)
	at com.jfinal.kit.JsonKit.toJson(JsonKit.java:202)
	at com.jfinal.kit.JsonKit.listToJson(JsonKit.java:99)
	at com.jfinal.kit.JsonKit.toJson(JsonKit.java:199)
	at com.jfinal.kit.JsonKit.toKeyValue(JsonKit.java:74)
	at com.jfinal.kit.JsonKit.mapToJson(JsonKit.java:60)
	at com.jfinal.render.JsonRender.buildJsonText(JsonRender.java:127)
	at com.jfinal.render.JsonRender.render(JsonRender.java:88)
	at com.jfinal.core.ActionHandler.handle(ActionHandler.java:94)
	at com.jfinal.core.JFinalFilter.doFilter(JFinalFilter.java:72)
	at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1307)
	at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:453)
	at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:137)
	at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:560)
	at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:231)
	at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1072)
	at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:382)
	at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:193)
	at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1006)
	at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135)
	at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)
	at org.eclipse.jetty.server.Server.handle(Server.java:365)
	at org.eclipse.jetty.server.AbstractHttpConnection.handleRequest(AbstractHttpConnection.java:485)
	at org.eclipse.jetty.server.AbstractHttpConnection.headerComplete(AbstractHttpConnection.java:926)
	at org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.headerComplete(AbstractHttpConnection.java:988)
	at org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:635)
	at org.eclipse.jetty.http.HttpParser.parseAvailable(HttpParser.java:235)
	at org.eclipse.jetty.server.AsyncHttpConnection.handle(AsyncHttpConnection.java:82)
	at org.eclipse.jetty.io.nio.SelectChannelEndPoint.handle(SelectChannelEndPoint.java:628)
	at org.eclipse.jetty.io.nio.SelectChannelEndPoint$1.run(SelectChannelEndPoint.java:52)
	at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608)
	at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:543)
	at java.lang.Thread.run(Thread.java:722)
Caused by: java.lang.IllegalAccessException: Class com.jfinal.kit.JsonKit can not access a member of class sun.misc.Launcher$ExtClassLoader with modifiers "public static"
	at sun.reflect.Reflection.ensureMemberAccess(Reflection.java:95)
	at java.lang.reflect.AccessibleObject.slowCheckMemberAccess(AccessibleObject.java:261)
	at java.lang.reflect.AccessibleObject.checkAccess(AccessibleObject.java:253)
	at java.lang.reflect.Method.invoke(Method.java:594)
	at com.jfinal.kit.JsonKit.beanToJson(JsonKit.java:245)
	... 63 more

通过调试发现,主要是Enum类的getDeclaringClass方法导致的。在类JsonKit的toJson方法中加入如下代码基本解决了该问题:

public static String toJson(Object value, int depth) {
	......
	if(value instanceof Enum)
			return "\"" + ((Enum)value).name() + "\"";
	......
}



加载中
2
pandyyan
pandyyan

renderJson(JSON.toJSONString(Obj));

JSON为fastjson工具类,renderJson好像本身json转化的能力较弱,主要作用是渲染json数据到客户端,所以json数据的转化改用fastjson或者其他第三方组件即可。

@JFinal ,@缪斯的情人 ,@绝望的八皮 给权威的回答。

会写代码的厨子
会写代码的厨子
非常感谢,帮我解决了一个大问题。
林林悦之
林林悦之
非常感谢
绝望的八皮
绝望的八皮
表示赞同,我没怎么多用jsonrender。不过如是是有比较复杂的json需要可以用fastjson等库
1
乐不可支
乐不可支

Enum内部也会有属性,Enum应该当成普通Model来转换json。出现上面的异常是因为Enum的getDeclaringClass()方法导致的,解析逻辑中把这个方法屏蔽掉就好了,beanToJson方法中if (!attrName.equals("Class"))改成

if (!attrName.equals("Class")
&& !attrName.equals("DeclaringClass")) { // Ignore
// Object.getClass()&&Enum.getDeclaringClass()


@JFinal

JFinal
JFinal
jfinal 1.6 版会尝试改进
0
JFinal
JFinal
Enum 的确是没有考虑到,谢谢你的建议 
返回顶部
顶部