php 接收ajax post数据格式,ajax POST json对象给PHP,PHP怎么接收值

ajax POST json对象给PHP,PHP如何接收值

本帖最后由 KtosMayCry 于 2014-07-04 20:30:03 编辑

前端:

$("#save_config_btn").click(function(){

$.ajaxSetup({

cache:false,

contentType : "application/x-www-form-urlencoded; charset=utf-8"

});

var fields = $("#rss_form").serializeArray();

fields = JSON.stringify(fields)  //中文会乱码

$.ajax({

type: "POST",

url : "edit.php",

data: fields,

success: function(msg){

alert(msg);

}

});

});

PHP:

header("Content-type: text/html; charset=UTF-8");

$data = $_POST['data'];

echo '

';

print_r($data);

?>

通过 JSON.stringify 获取到的json格式如下:

[{ "name":"Bill" , "value":"Gates" },

{ "name":"George" , "value":"Bush" },

{ "name":"Thomas" , "value":"Carter" }]

PHP,这里POST的接收值不知道用什么,如果把上面的json字符串改成如下格式,那么PHP即可接受到并直接返回数组格式

{"data":[{ "name":"Bill" , "value":"Gates" },

{ "name":"George" , "value":"Bush" },

{ "name":"Thomas" , "value":"Carter" }]}

总结下主要想问两个问题:

1、JQuery如何把serializeArray()获取到的json对象转换为 第二种格式的json字符串 且保证中文不会乱码

2、或者php如何直接接收 json对象 或者 第一种格式的 json字符串

------解决方案--------------------

1、JQuery如何把serializeArray()获取到的json对象转换为 第二种格式的json字符串 且保证中文不会乱码

保证不乱码,需要在header加入

第二种数组格式

var fields = $("#rss_form").serializeArray();

var t = {};

t['data'] = fields

fields = JSON.stringify(t);

2、或者php如何直接接收 json对象 或者 第一种格式的 json字符串

用第一种json字符串提交例子:

HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

 js test 

var fields = [{ "name":"中文" , "value":"中文" },{ "name":"中文" , "value":"中文" },{ "name":"中文" , "value":"中文" }];

fields = "data=" + JSON.stringify(fields);

$.ajax({

type: "POST",

url : "demo.php",

data: fields,

success: function(msg){

alert(msg);

}

});

demo.php

$data = $_POST['data'];

file_put_contents('test.log', $data, true);

echo "ok";

?>

运行后:

test.log内容为[{"name":"中文","value":"中文"},{"name":"中文","value":"中文"},{"name":"中文","value":"中文"}]

如果没有加 则会乱码。

------解决方案--------------------

1、ajax 本身就是以 utf-8 编码传输,所以不需要再有 charset=utf-8 声明

2、jq 的 post 方式已经发了 application/x-www-form-urlencoded 头,也不需要你再劳动了

所以$.ajaxSetup({

cache:false,

contentType : "application/x-www-form-urlencoded; charset=utf-8"

});一段是不需要的。考虑的 IE 的缓存可能会影响效果,可以把 cache: false 作为 $.ajax 的参数$.ajax({

cache: false,

type: "POST",

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值