收藏本站 收藏本站
积木网首页 - 软件测试 - 常用手册 - 站长工具 - 技术社区
积木学院 > 网页设计 > XML > 正文

大致说明JSON 对象的相关使用字符

来源:互联网 日期:2013-04-16 13:05

简单地说,JSON 对象可以将 JavaScript 对象中表示的一组数据转换为字符串,然后就可以在函数之间轻松地传递这个字符串,或者在异步应用程序中将字符串从 Web 客户机传递给服务器端程序。

这个字符串看起来有点儿古怪(稍后会看到几个示例),但是 JavaScript 很容易解释它,而且 JSON 可以表示比名称/值对更复杂的结构。例如,可以表示数组和复杂的对象,而不仅仅是键和值的简单列表。

当需要表示一组值时,JSON 不但能够提高可读性,而且可以减少复杂性:

  1. { "programmers": [  
  2.     { "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" },  
  3.     { "firstName": "Jason", "lastName":"Hunter", "email": "jason@servlets.com" },  
  4.     { "firstName": "Elliotte", "lastName":"Harold", "email": "elharo@macfaq.com" }  
  5.    ],  
  6. "authors": [  
  7.     { "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" },  
  8.     { "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" },  
  9.     { "firstName": "Frank", "lastName": "Peretti", "genre": "christian fiction" }  
  10.    ],  
  11. "musicians": [  
  12.     { "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" },  
  13.     { "firstName": "Sergei", "lastName": "Rachmaninoff", "instrument": "piano" }  
  14.    ]  

至此,您应该从技术角度对如何在服务器端处理 JSON 有了基本的把握。本篇文章和本系列的 第 10 部分 不仅提供了技术层面的帮助,而且还向您展示了 JSON 是一种多么灵活、强大的数据格式。即使您不会在每个应用程序中都使用 JSON,但优秀的 Ajax 和 JavaScript 程序员的工具箱中总少不了 JSON 以备不时之需。

我当然很希望能够分享您的JSON 对象使用经验以及您对何种语言更善于在服务器端处理 JSON 数据的高见。您可以访问 Java 和 XML 新闻组(有关链接,请参阅 参考资料 部分)跟我联系。享受JSON 对象和文本数据格式的乐趣吧。

  1. public void doPost(HttpServletRequest request, HttpServletResponse response)  
  2. throws ServletException, IOException {  
  3.  
  4. StringBuffer jb = new StringBuffer();  
  5. String line = null;  
  6. try {  
  7.     BufferedReader reader = request.getReader();  
  8.     while ((line = reader.readLine()) != null)  
  9.       jb.append(line);  
  10. } catch (Exception e) { //report an error }  
  11.  
  12. try {  
  13.     JSONObject jsonObject = new JSONObject(jb.toString());  
  14. } catch (ParseException e) {  
  15.     // crash and burn  
  16.     throw new IOException("Error parsing JSON request string");  
  17. }  
  18.  
  19. // Work with the data using methods like...  
  20. // int someInt = jsonObject.getInt("intParamName");  
  21. // String someString = jsonObject.getString("stringParamName");  
  22. // JSONObject nestedObj = jsonObject.getJSONObject("nestedObjName");  
  23. // JSONArray arr = jsonObject.getJSONArray("arrayParamName");  
  24. // etc...  

尽管看起来不明显,但是上面的长字符串实际上只是一个数组;将这个数组放进 JavaScript 变量之后,就可以很轻松地访问它。实际上,只需用点号表示法来表示数组元素。所以,要想访问 programmers 列表的第一个条目的姓氏,只需在 JavaScript 中使用下面这样的代码:

  1. String newJSONtext = people.toJSONString();     //value is "McLaughlin" 

不管在服务器端使用何种语言,在服务器端处理JSON 对象基本上就需要两个步骤:
1.针对编写服务器端程序所用的语言,找到相应的 JSON 解析器/工具箱/帮助器 API。
2.使用 JSON 解析器/工具箱/帮助器 API 取得来自客户机的请求数据并将数据转变成脚本能理解的东西。


推荐阅读

 

热点信息

 
强悍的草根IT技术社区,这里应该有您想要的! 友情链接:b2b电子商务
Copyright © 2010 Gimoo.Net. All Rights Rreserved  京ICP备05050695号