
List<Article>al = articleMng.find(f)
System.out.println(al.size())
HttpServletResponse hsr = ServletActionContext.getResponse()
if(null == al){
return
}
for(Article a : al){
System.out.println(a.getId()+a.getDescription()+a.getTitle())
}
JSONArray json = new JSONArray()
for(Article a : al){
JSONObject jo = new JSONObject()
jo.put("id", a.getId())
jo.put("title", a.getTitle())
jo.put("desc", a.getDescription())
json.put(jo)
}
try {
System.out.println(json.toString())
hsr.setCharacterEncoding("UTF-8")
hsr.getWriter().write(json.toString())
} catch (IOException e) {
e.printStackTrace()
}
上述代码JSONArray是引入的org.json.JSONArray包
而用net.sf.json包下JSONArray的静态方法:fromObject(list) 这是网上大多是都是直接用此方法快捷转换JSON,但是对于Hibernate级联 *** 作关联的对象,这个方法就会报错,如果将映射文件中的级联配置去掉就行了。
另外对于list的要求就是其中的元素是字符串或对象,否则JSON不知道你想要的是什么数据。
<many-to-one name="cmsent" column="comment_tid" class="com.fcms.cms.entity.CmsComment"
not-null="false" cascade="delete">
但是级联 *** 作毕竟还是得存在,否则以后数据冗余、多余。
解决方法就是:JSONArray subMsgs = JSONArray.fromObject(object, config)
JsonConfig config = new JsonConfig()
config.setJsonPropertyFilter(new PropertyFilter() {
public boolean apply(Object arg0, String arg1, Object arg2) {
if (arg1.equals("article") ||arg1.equals("fans")) {
return true
} else {
return false
}
}
})
说明:提供了一个过滤作用,如果遇到关联的对象时他会自动过滤掉,不去执行关联关联所关联的对象。这里我贴出我hibernate中的配置关系映射的代码帮助理解:
<!-- 配置话题和团体之间的关系 -->
<many-to-one name="article" class="com.fcms.nubb.article" column="article_id"/>
<!-- 配置主题帖与回复的帖子之间的关系 -->
<set name="subMessages" table="sub_message" inverse="true" cascade="all" lazy="false" order-by="date asc">
<key column="theme_id" />
<one-to-many class="bbs.po.SubMessage" />
</set>
如果要把List转换成json,则需要List中是套map的形式就可以的。在action中把list放入request,在jsp页面中在request取到list结果集并且用javascript的eval()方法或者使用第三方的json包都可以把List中存放map的数据转换成json的。
不懂你什么意思。url接口去访问数据?是访问一般处理程序?如果是:
把你得到list集合转成json,直接Response.Write(json)
不会转json,OK 引用Newtonsoft(网上下个dll)
用var json = JsonConvert.SerializeObject(list)
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)