博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何使用JSON格式 POST数据到服务器
阅读量:5309 次
发布时间:2019-06-14

本文共 4420 字,大约阅读时间需要 14 分钟。

1. JSON的数据格式 a)         按照最简单的形式,可以用下面这样的 JSON 表示名称/值对: { "firstName": "Brett" } b)        可以创建包含多个名称/值对的记录,比如: { "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" } c)         可以创建值的数组 { "people": [  { "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" },  { "firstName": "Jason", "lastName":"Hunter", "email": "jason@servlets.com" } ]} d)        当然,可以使用相同的语法表示多个值(每个值包含多个记录): { "programmers": [  { "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" },  { "firstName": "Jason", "lastName":"Hunter", "email": "jason@servlets.com" }  ], "authors": [  { "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" },  { "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" } ], "musicians": [  { "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" } ] } 注意,在不同的主条目(programmers、authors 和 musicians)之间,记录中实际的名称/值对可以不一样。JSON 是完全动态的,允许在 JSON 结构的中间改变表示数据的方式。 2. 在  中使用 JSON JSON 是  原生格式,这意味着在  中处理 JSON 数据不需要任何特殊的 API 或工具包。 2.1   将 JSON 数据赋值给 例如,可以创建一个新的 JavaScript ,然后将 JSON 格式的数据字符串直接赋值给它: var people =  { "programmers": [     { "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" },     { "firstName": "Jason", "lastName":"Hunter", "email": "jason@servlets.com" }    ],  "authors": [     { "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" },     { "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" }    ],  "musicians": [     { "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" }    ]  } 2.2   访问数据 将这个数组放进 JavaScript 之后,就可以很轻松地访问它。实际上,只需用点号表示法来表示数组元素。所以,要想访问 programmers 列表的第一个条目的姓氏,只需在JavaScript 中使用下面这样的代码: people.programmers[0].lastName; 注意,数组索引是从零开始的。 2.3   修改 JSON 数据 正如访问数据,可以按照同样的方式修改数据: people.musicians[1].lastName = "Rachmaninov"; 2.4   转换回字符串 a)         在 JavaScript 中这种转换也很简单: String  newJSONtext  =  people.toJSONString(); b)        可以将任何 JavaScript 对象转换为 JSON 文本。并非只能处理原来用 JSON 字符串赋值的变量。为了对名为 myObject 的对象进行转换,只需执行相同形式的命令: String  myObjectInJSON  =  myObject.toJSONString(); 说明:将转换回的字符串作为Ajax调用的字符串,完成异步传输。 小结:如果要处理大量 JavaScript 对象,那么 JSON 几乎肯定是一个好选择,这样就可以轻松地将数据转换为可以在请求中发送给程序的格式。 3. 的 JSON 3.1   将 JSON 发给服务器 a)         通过 GET 以名称/值对发送 JSON 在 JSON 数据中会有空格和各种字符,Web 浏览器往往要尝试对其继续编译。要确保这些字符不会在服务器上(或者在将数据发送给服务器的过程中)引起混乱,需要在JavaScript的escape()函数中做如下添加: var url = "organizePeople.php?people=" + escape(people.toJSONString()); request.open("GET", url, true); request.onreadystatechange = updatePage; request.send(null); b)         利用 POST 请求发送 JSON 数据 当决定使用 POST 请求将 JSON 数据发送给服务器时,并不需要对代码进行大量更改,如下所示: var url = "organizePeople.php?timeStamp=" + new Date().getTime(); request.open("POST", url, true); request.onreadystatechange = updatePage; request.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); request.send(people.toJSONString()); 注意:赋值时格式必须是var msg=eval('(' + req.responseText + ')'); 3.2   在服务器上解释 JSON a)       处理 JSON 的两步骤。  针对编写程序所用的语言,找到相应的 JSON 解析器/工具箱/帮助器 API。  使用 JSON 解析器/工具箱/帮助器 API 取得来自客户机的请求数据并将数据转变成脚本能理解的东西。 b)      寻找 JSON 解析器 寻找 JSON 解析器或工具箱最好的资源是 JSON 站点。如果使用的是 Java servlet,json.org 上的 org.json 包就是个不错的选择。在这种情况下,可以从 JSON Web 站点下载 json.zip 并将其中包含的源文件添加到项目构建目录。编译完这些文件后,一切就就绪了。对于所支持的其他语言,同样可以使用相同的步骤;使用何种语言取决于您对该语言的精通程度,最好使用您所熟悉的语言。 c)       使用 JSON 解析器 一旦获得了程序可用的资源,剩下的事就是找到合适的方法进行调用。如果在 servlet 中使用的是 org.json 包,则会使用如下代码: public void doPost(HttpServletRequest request, HttpServletResponse response)  throws ServletException, IOException {
StringBuffer jb = new StringBuffer(); String line = null; try {
BufferedReader reader = request.getReader(); while ((line = reader.readLine()) != null) jb.append(line); } catch (Exception e) { //report an error } try {
JSONObject jsonObject = new JSONObject(jb.toString()); } catch (ParseException e) {
// crash and burn throw new IOException("Error parsing JSON request string"); } // Work with the data using methods like... // int someInt = jsonObject.getInt("intParamName"); // String someString = jsonObject.getString("stringParamName"); // JSONObject nestedObj = jsonObject.getJSONObject("nestedObjName"); // JSONArray arr = jsonObject.getJSONArray("arrayParamName"); // etc... } 摘自:http://zhidao.baidu.com/link?url=uA8_iHp-exq9yHLzCFSpqc3zHxsmQA74I_jzTaM_S-BzJs7B0r9rutiFthpO87H1h1EYTNVdkmOh7n_RnsYiolzWp50FQpYlaWXIhDjPENS

转载于:https://www.cnblogs.com/antyi/p/5567353.html

你可能感兴趣的文章
完成登录功能,用session记住用户名
查看>>
创建型模式 -> 结构型模式/行为模式
查看>>
Java内存分析
查看>>
[ CodeVS冲杯之路 ] P1098
查看>>
[数据库]Oracle和mysql中的分页总结
查看>>
iOS-----App闪退,程序崩溃---解决方案
查看>>
Vue使用axios
查看>>
Docker入门系列(三):让你的应用变为可扩展的服务
查看>>
爬虫开发13.UA池和代理池在scrapy中的应用
查看>>
用多线程处理FTP上传
查看>>
点击事件在label标签执行2次解决办法
查看>>
第二篇:R语言数据可视化之数据塑形技术
查看>>
刀塔传奇公会管理系统 ------ Pgsql 后台
查看>>
[Swift]LeetCode735. 行星碰撞 | Asteroid Collision
查看>>
实验吧程序逻辑问题
查看>>
jQuery幻灯片插件pbTouchSlider
查看>>
Windows下安装jenkins,关闭jenkins,修改jenkins端口号
查看>>
《Java程序设计》第十周学习总结
查看>>
[Javascript] Classify JSON text data with machine learning in Natural
查看>>
[CSS] DOM Hierarchy Pseudo Classes :first-child :last-child :nth-child (demystified)
查看>>