开发者社区> 问答> 正文

JFinal的renderJson在处理Enum的问题?报错

@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() + "\"";
	......
}



展开
收起
爱吃鱼的程序员 2020-06-22 20:07:05 644 0
1 条回答
写回答
取消 提交回答
  • https://developer.aliyun.com/profile/5yerqm5bn5yqg?spm=a2c6h.12873639.0.0.6eae304abcjaIB

    renderJson(JSON.toJSONString(Obj));

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

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

    非常感谢,帮我解决了一个大问题。非常感谢表示赞同,我没怎么多用jsonrender。不过如是是有比较复杂的json需要可以用fastjson等库

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

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


    @JFinal

    jfinal1.6版会尝试改进Enum的确是没有考虑到,谢谢你的建议 
    2020-06-23 11:51:59
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
introduction to Apache Bean 立即下载
Apache Wicket User Guide - Ref 立即下载
低代码开发师(初级)实战教程 立即下载