如何使用JSON格式 POST数据到服务器

如何使用JSON格式 POST数据到服务器,第1张

1. JSON的数据格式a) 按照最简单的形式,可以用下面这样的 JSON 表示名称/值对:{ "firstName": "Brett" }b) 可以创建包含多个名称/值对的记录,比如:{ "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstancecom" }c) 可以创建值的数组{ "people": [ { "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstancecom" }, { "firstName": "Jason", "lastName":"Hunter", "email": "jason@servletscom" }]}d) 当然,可以使用相同的语法表示多个值(每个值包含多个记录):{ "programmers": [ { "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstancecom" }, { "firstName": "Jason", "lastName":"Hunter", "email": "jason@servletscom" } ],"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. 在 JavaScript 中使用 JSONJSON 是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON 数据不需要任何特殊的 API 或工具包。
21 将 JSON 数据赋值给变量例如,可以创建一个新的 JavaScript 变量,然后将 JSON 格式的数据字符串直接赋值给它:var people = { "programmers": [ { "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstancecom" }, { "firstName": "Jason", "lastName":"Hunter", "email": "jason@servletscom" } ], "authors": [ { "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" }, { "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" } ], "musicians": [ { "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" } ] }
22 访问数据将这个数组放进 JavaScript 变量之后,就可以很轻松地访问它。实际上,只需用点号表示法来表示数组元素。所以,要想访问 programmers 列表的第一个条目的姓氏,只需在JavaScript 中使用下面这样的代码:peopleprogrammers[0]lastName;注意,数组索引是从零开始的。
23 修改 JSON 数据正如访问数据,可以按照同样的方式修改数据:peoplemusicians[1]lastName = "Rachmaninov";
24 转换回字符串a) 在 JavaScript 中这种转换也很简单:String newJSONtext = peopletoJSONString();b) 可以将任何 JavaScript 对象转换为 JSON 文本。并非只能处理原来用 JSON 字符串赋值的变量。为了对名为 myObject 的对象进行转换,只需执行相同形式的命令:String myObjectInJSON = myObjecttoJSONString();说明:将转换回的字符串作为Ajax调用的字符串,完成异步传输。小结:如果要处理大量 JavaScript 对象,那么 JSON 几乎肯定是一个好选择,这样就可以轻松地将数据转换为可以在请求中发送给服务器端程序的格式。
3. 服务器端的 JSON31 将 JSON 发给服务器a)
通过 GET 以名称/值对发送 JSON在 JSON 数据中会有空格和各种字符,Web 浏览器往往要尝试对其继续编译。要确保这些字符不会在服务器上(或者在将数据发送给服务器的过程中)引起混乱,需要在JavaScript的escape()函数中做如下添加:var url = "organizePeoplephppeople=" + escape(peopletoJSONString());requestopen("GET", url, true);requestonreadystatechange = updatePage;requestsend(null);b) 利用 POST 请求发送 JSON 数据当决定使用 POST 请求将 JSON 数据发送给服务器时,并不需要对代码进行大量更改,如下所示:var url = "organizePeoplephptimeStamp=" + new Date()getTime();requestopen("POST", url, true);requestonreadystatechange = updatePage;requestsetRequestHeader("Content-Type", "application/x-(>jquery 的$post方法
function sendAjax(){
var userinfoRef = new userinfo('毛主席','1001');
var jsonStringRef = JSONstringify(userinfoRef);
$post("url",{
jsonString : jsonStringRef
});
}、
在后台定义一个String jsonString同名变量,来接收前台的jsonString 字符串即可。

get和post方法功能类似的,使用建议:
1、get方式的安全性较Post方式要差些,包含机密信息的话,建议用Post数据提交方式; 2、在做数据查询时,建议用Get方式;而在做数据添加、修改或删除时,建议用Post方式;
区别表现如下:
1 get是从服务器上获取数据,post是向服务器传送数据。 2 get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。post是通过>是的,使用POST接口可以查询下拉框数据。POST接口可以通过向服务器发送请求来获取下拉框数据。POST请求可以携带大量数据,因此可以查询更多的下拉框数据。另外,POST请求不会将数据显示在URL上,因此可以更好地保护数据的安全性。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/10693668.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-10
下一篇 2023-05-10

发表评论

登录后才能评论

评论列表(0条)

保存