Gson gson = new Gson(); 。
String json = "{\"log_id\": 7978654499008785461, \"direction\": 3, \"words_result_num\": 5, \"words_result\": [{\"words\": \"1.5.2复变函数的极限与连续性\"}, {\"words\": \"定义1.1设函数W=f(z)在z0的去心邻域0<|z-z0<p内有\"}, {\"words\": \"定义.若有确定的复数A(A≠∞)存在,对于任意给定的e>0,总存在\"}, {\"words\": \"个正数,使得对满足0<|z-z0<0(0<8≤p)的一切z,都有\"}, {\"words\": \"(x)-A|<e,则称A为函数f(z)当z趋向z0时的极限.记作\"}]}";。
Map<String,Object> data = gson.fromJson(json,Map.class); 。
List<Map<String,Object>> list = (List<Map<String,Object>>)data.get("words_result");。
StringBuffer words = new StringBuffer();。
for(Map<String,Object> map : list){。
words.append(map.get("words"));。
}
System.out.println(words.toString());。
将json转化为数组,再读取就可以了。
如: $arr = json_decode($json,true);//后面加个true返回的是数组,不加true返回的是对象。
1. 简单的手动放置 键值对 到JSONObject,然后在put到JSONArray对象里。
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>。
总结:
1. JSONArray subMsgs = JSONArray.fromObject(subMessages, config);其中config是可选的,当出现上面的情况是可以配置config参数,如果没有上面的那种需求就可以直接使用fromObject(obj)方法,它转换出来的就是标准的json对象格式的数据,如下:
{["attr", "content", ...}, ...]}。
2. JSONObject jTmsg = JSONObject.fromObject(themeMessage, config);这是专门用来解析标准的pojo,或者map对象的,pojo对象的格式就不用说了,map的形式是这样的{"str", "str"}。
package com.nubb.bean;。
import java.io.Serializable;。
public class Person implements Serializable{。
private static final long serialVersionUID = 1L;。
private String name;。
private int age;。
private String address;。
public String getName() {。
return name;。
}
public void setName(String name) {。
this.name = name;。
}
public int getAge() {。
return age;。
}
public void setAge(int age) {。
this.age = age;。
}
public String getAddress() {。
return address;。
}
public void setAddress(String address) {。
this.address = address;。
}
package com.nubb.test;。
import java.io.IOException;。
import java.nio.file.Files;。
import java.nio.file.Path;。
import java.nio.file.StandardOpenOption;。
import java.util.ArrayList;。
import java.util.List;。
import com.alibaba.fastjson.JSON;。
import com.nubb.bean.Person;。
public class JSONSerializer {。
private static final String DEFAULT_CHARSET_NAME = "UTF-8";。
public static <T> String serialize(T object) {。
return JSON.toJSONString(object);。
}
public static <T> T deserialize(String string, Class<T> clz) {。
return JSON.parseObject(string, clz);。
}
public static <T> T load(Path path, Class<T> clz) throws IOException {。
return deserialize(。
new String(Files.readAllBytes(path), DEFAULT_CHARSET_NAME), clz);。
}
public static <T> void save(Path path, T object) throws IOException {。
if (Files.notExists(path.getParent())) {。
Files.createDirectories(path.getParent());。
}
Files.write(path,。
serialize(object).getBytes(DEFAULT_CHARSET_NAME),。
StandardOpenOption.WRITE,。
StandardOpenOption.CREATE,。
StandardOpenOption.TRUNCATE_EXISTING);。
}
public static void main(String[] args) {。
Person person1 = new Person();。
person1.setAddress("address");。
person1.setAge(11);。
person1.setName("amao");。
Person person2 = new Person();。
person2.setAddress("address");。
person2.setAge(11);。
person2.setName("amao");。
List<Person> lp = new ArrayList<Person>();。
lp.add(person1);。
lp.add(person2);。
System.out.println(serialize(lp));。
}
输出:
[{"address":"address","age":11,"name":"amao"},{"address":"address","age":11,"name":"amao"}]。
这个不清楚,不知道你是什么浏览器,我现在用的手机QQ浏览器,功能很全面。
独家支持最全高清视频网站,包括:优酷、土豆、奇艺、QQLive、皮皮等。
2. 超快超省流量:最快引擎内核,通过中转,数据压缩,流量节省可高达90%。 3. 双模式浏览解析:互联网模式、简单模式一键切换,手机和PC两种体验。
4. 阅读模式看小说:智能记忆阅读章节,向下滑动屏幕自动加载内容。
Web Service接口方法。
[WebMethod]
public string Project(string paramaters)。
return paramaters;。
实现代码
public string Post(string methodName, string jsonParas)。
string strURL = Url + "/" + methodName;。
//创建一个HTTP请求
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(strURL);。
//Post请求方式
request.Method = "POST";。
//内容类型
request.ContentType = "application/x-www-form-urlencoded";。
//设置参数,并进行URL编码。
//虽然我们需要传递给服务器端的实际参数是JsonParas(格式:[{\"UserID\":\"0206001\",\"UserName\":\"ceshi\"}]),
//但是需要将该字符串参数构造成键值对的形式(注:"paramaters=[{\"UserID\":\"0206001\",\"UserName\":\"ceshi\"}]"),
//其中键paramaters为WebService接口函数的参数名,值为经过序列化的Json数据字符串。
//最后将字符串参数进行Url编码。
string paraUrlCoded = System.Web.HttpUtility.UrlEncode("paramaters");。
paraUrlCoded += "=" + System.Web.HttpUtility.UrlEncode(jsonParas);。
byte[] payload;。
//将Json字符串转化为字节。
payload = System.Text.Encoding.UTF8.GetBytes(paraUrlCoded);。
//设置请求的ContentLength。
request.ContentLength = payload.Length;。
//发送请求,获得请求流
Stream writer;
try
writer = request.GetRequestStream();//获取用于写入请求数据的Stream对象。
catch (Exception)。
writer = null;
Console.Write("连接服务器失败!");。
//将请求参数写入流
writer.Write(payload, 0, payload.Length);。
writer.Close();//关闭请求流。
String strValue = "";//strValue为http响应所返回的字符流。
HttpWebResponse response;。
try
//获得响应流
response = (HttpWebResponse)request.GetResponse();。
catch (WebException ex)。
response = ex.Response as HttpWebResponse;。
Stream s = response.GetResponseStream();。
//服务器端返回的是一个XML格式的字符串,XML的Content才是我们所需要的Json数据。
XmlTextReader Reader = new XmlTextReader(s);。
Reader.MoveToContent();。
strValue = Reader.ReadInnerXml();//取出Content中的Json数据。
Reader.Close();。
s.Close();
return strValue;//返回Json数据。
Url的格式样例:"http://59.68.29.106:8087/IFT_Project.asmx"。
methodName参数就是"Project"。
JsonParas就是使用C# JavaScriptSerializer将List<Object>类型的对象序列化之后得到的值,数据格式:[{\"UserID\":\"0206001\",\"UserName\":\"ceshi\"}],Json数据中的中括号代表由着多个对象集合序列化,花括号代表一个对象序列化得到的结果,花括号里面的内容使用键值对的方式展示,多个属性之间用逗号隔开,每个对象也用逗号隔开。
request.ContentType必须设置值,建议使用"application/x-www-form-urlencoded",设置其他值就很容易报服务器内部异常,使用这种方式服务接口方法返回的是xml格式的字符串。
payload将请求参数转换成二进制来保存,此处一定要将“paramaters”加入其中,不然会报异常缺少参数,paramaters就是服务接口函数的参数名。函数中使用了URL编码,注意在编码的时候只需要将键和值进行编码,不要将中间的=进行编码,不然getResponse的时候会报异常。
request.ContentLength也是必须设置的值。
在得到响应流之后Stream s = response.GetResponseStream();需要使用Reader来解析响应流,这个地方我使用的是XmlTextReader,因为我服务方法返回的是xml格式的字符串,其中Json数据在xml的Content中。在取出Json数据之后,再进行相应的反序列化即可得到对象。