前端学习——使用Ajax方式POST JSON数据包

news/2024/7/11 1:08:50 标签: ajax, jquery, post, json
0.前言
    本文解释如何使用Jquery中的ajax方法传递JSON数据包,传递的方法使用POST(当然PUT又有时也是一个不错的选择)。POST JSON数据包相比标准的POST格式可读性更好些,层次结构也更清晰。
    为了说明问题,前端和后端较为简单,重点突出AJAX的应用。
    【前端】——add-post-json.html

图1 add页面
    【后端】——add-post-json.php
<?php
// 返回JSON格式
header('Content-Type:application/json;charset=utf-8');
$result = array();

// 获得原始输入内容
$json = file_get_contents("php://input");
//var_dump($input_str);

// JSON转换为PHP对象
$obj = json_decode($json);

$a = $obj->a; // var_dump($a);
$b = $obj->b; // var_dump($b);

$result["result"] = $a + $b;
echo json_encode($result, JSON_NUMERIC_CHECK);
?>

    【代码仓库】—— test-jquery-ajax
     代码仓库位于bitbucket使用Hg(而不是Git),Hg在windows或ubuntu上均有很好用的GUI工具——TortoiseHg,本人愚笨没能熟练掌握Git。
    【 TortoiseHg使用说明】——如果没有使用过Hg请参考博文hg clone部分操作即可。   
    【 JQuery 中文API】
    【相关博文】
    【 前端学习——JQuery Ajax使用经验】

1.POST JSON数据包
    var submit_sync = function() {
        $.ajax({
            type: "post",
            url: 'add-post-json.php',
            async: false, // 使用同步方式
            // 1 需要使用JSON.stringify 否则格式为 a=2&b=3&now=14...
            // 2 需要强制类型转换,否则格式为 {"a":"2","b":"3"}
            data: JSON.stringify({                  
                a: parseInt($('input[name="a"]').val()),
                b: parseInt($('input[name="b"]').val()),
                now: new Date().getTime() // 注意不要在此行增加逗号
            }),
            contentType: "application/json; charset=utf-8",
            dataType: "json",
            success: function(data) {
                $('#result').text(data.result);
            } // 注意不要在此行增加逗号
        });
    }

【HTTP请求部分内容】
POST /test-jquery-ajax/add-post-json.php HTTP/1.1 
Host: 192.168.1.104 
Connection: keep-alive 
Content-Length: 35 
Accept: application/json, text/javascript, */*; q=0.01 
X-Requested-With: XMLHttpRequest 
Content-Type: application/json; charset=UTF-8 

{"a":12,"b":34,"now":1403525674676}

【HTTP响应部分内容】
HTTP/1.1 200 OK
Content-Length: 13
Content-Type: application/json;charset=utf-8
{"result":46}

2.重要说明
【1】
需要使用 JSON.stringify 否则HTTP请求为a=12&b=34。
以下写法并不能达到POST JSON数据包的效果,这是标准的POST格式。
data: {                  
    a: parseInt($('input[name="a"]').val()),
    b: parseInt($('input[name="b"]').val()),
    now: new Date().getTime() // 注意不要在此行增加逗号
},
【HTTP请求部分内容】
POST /test-jquery-ajax/add-post-json.php HTTP/1.1 
Host: 192.168.1.104 
Content-Length: 27 
X-Requested-With: XMLHttpRequest 
Content-Type: application/json; charset=UTF-8 


a=12&b=34&now=1403525989275

【2】
需要强制类型转换 parseInt(),否则HTTP请求为 {"a":"12","b":"34"}
以下代码并不能达到预期效果
data: JSON.stringify({                  
    a: $('input[name="a"]').val(),
    b: $('input[name="b"]').val(),
    now: new Date().getTime() // 注意不要在此行增加逗号
}),
【HTTP请求部分内容】
POST /test-jquery-ajax/add-post-json.php HTTP/1.1 
Host: 192.168.1.104 
Content-Length: 39 
X-Requested-With: XMLHttpRequest 
Content-Type: application/json; charset=UTF-8 


{"a": "12" ,"b": "34" ,"now":1403526427890}

【3】
IE8兼容,IE7和IE6 不支持JSON.stringify,使用请慎重。


http://www.niftyadmin.cn/n/671105.html

相关文章

speedoffice(PPT)怎么给文字加粗

我们在制作PPT时&#xff0c;一些文字尤其是标题通常需要加粗&#xff0c;那么怎么给文字加粗呢&#xff1f;看看小编怎么操作的吧。 首先选择需要加粗的文字&#xff0c;如图&#xff1a; 然后选择“主页”里面的“加粗”或者用快捷键CtrlB 最后&#xff0c;点击加粗后我们就…

delphi字符串操作函数一览

首部 function SameText(const S1, S2: string): Boolean; $[SysUtils.pas功能 返回两个字符串是否相等说明 不区分大小写参考 <NULL>例子 CheckBox1.Checked : SameText(Edit1.Text, Edit2.Text);━━━━━━━━━━━━━━━━━━━━━首部 function AnsiUpperCas…

CAD怎么转成PDF呢?以最常见的Speedpdf在线为例

CAD怎么转成PDF呢&#xff1f;以最常见的speedpdf在线为例。 首先&#xff0c;推荐一款名的speedpdf的在线转换&#xff0c;网址为&#xff1a;https://speedpdf.com/zh-cn/&#xff0c;打开后页面如图所示&#xff1a; 然后&#xff0c;选择CAD转PDF 接着&#xff0c;在转换页…

构造哈夫曼数及哈夫曼编码

/*构造哈夫曼数及哈夫曼编码*/ #include<iostream> using namespace std; #define Maxlen 100 typedef struct {int weight;int lchild,rchild,parent; }HTNode; typedef HTNode Hfmt[Maxlen]; int n; void InitHfmt(Hfmt T) {int i;printf("\n\t\t请输入共有多少个…

JS字符串截取,按字节截取

/*字符串长度*/ function len(s) { var l 0; var a s.split(""); for (var i0;i<a.length;i) { if (a[i].charCodeAt(0)<299) { l; } else { l2; } } return l; } function str_limit(str,limit){ var l 0; var a str.split(""); var i0; for (i…

speedoffice(PPT)怎么添加下划线

PPT怎么添加下划线呢&#xff1f;以最常见的speedoffice为例 首先&#xff0c;选中需要添加下划线的文字&#xff0c;如图 接着&#xff0c;选择“主页”菜单栏里面的“下划线”工具或者用快捷键CtrlU 最后&#xff0c;点击下划线工具后&#xff0c;我们能看到被选中的文字已经…

TalkingData Cocos2dx在android平台使用总结

前言&#xff1a;最近发现很多朋友在使用TalkingData游戏版本Cocos2dx SDK使用过程中会出现的一些问题&#xff0c;今天来做一下总结&#xff0c;希望对您有所帮助&#xff1a; 首先非常感谢您使用TalkingData游戏统计平台&#xff0c;我们的成长跟您的反馈密不可分&#xff0c…

hadoop如何跑通第一个例子wordcount

1.进入你安装的hadoop的目录下&#xff0c;执行bin/hadoop namenode -format&#xff08;对文件系统进行格式 化&#xff09; 2.执行bin/start-all.sh&#xff0c;启动hadoop的所有守护进程&#xff0c;然后用jps查看相关的进程起来没&#xff0c;如 果是伪分布式环境下&#x…