后退 刷新 前进 收藏 顶部 |   知道 黑匣子 富媒体 技术服务

php 的json_encode

程序猿 PHP php json encode... (shuke.2016-07-08 08:09)
php 的json_encode能把数组转换为json格式的字符串。字符串没有缩进,中文会转为unicode编码,例如\u975a\u4ed4。人阅读比较困难。现在这个方法在json_encode的基础上再进行一次美化处理。使人能方便阅读内容。
<?php

/** Json数据格式化
* @param Mixed $data 数据
* @param String $indent 缩进字符,默认4个空格
* @return JSON
*/
function jsonFormat($data, $indent=null){
// 对数组中每个元素递归进行urlencode操作,保护中文字符
array_walk_recursive($data, 'jsonFormatProtect');
// json encode
$data = json_encode($data);

// 将urlencode的内容进行urldecode
$data = urldecode($data);

// 缩进处理
$ret = '';
$pos = 0;
$length = strlen($data);
$indent = isset($indent)? $indent : ' ';
$newline = "\n";
$prevchar = '';
$outofquotes = true;

for($i=0; $i<=$length; $i++){

$char = substr($data, $i, 1);

if($char=='"' && $prevchar!='\\'){
$outofquotes = !$outofquotes;
}elseif(($char=='}' || $char==']') && $outofquotes){
$ret .= $newline;
$pos --;
for($j=0; $j<$pos; $j++){
$ret .= $indent;
}
}

$ret .= $char;

if(($char==',' || $char=='{' || $char=='[') && $outofquotes){
$ret .= $newline;
if($char=='{' || $char=='['){
$pos ++;
}

for($j=0; $j<$pos; $j++){
$ret .= $indent;
}
}

$prevchar = $char;
}

return $ret;
}

/** 将数组元素进行urlencode
* @param String $val
*/
function jsonFormatProtect(&$val){
if($val!==true && $val!==false && $val!==null){
$val = urlencode($val);
}
}

header('content-type:application/json;charset=utf8');

$arr = array(
'status' => true,
'errMsg' => '',
'member' =>array(
array(
'name' => '李逍遥',
'gender' => '男'
),
array(
'name' => '赵灵儿',
'gender' => '女'
)
)
);
echo jsonFormat($arr);
?>


2 楼 shuke[2016-07-15 18:12]
使用JQUERY.JSON.JS
<script type="text/javascript" src="source/js/jquery.js"></script>
<script type="text/javascript" src="source/js/jquery_json.js"></script>

<script type="text/javascript">
function sendJson() {
var requestStr = {
reqStr: 'test parameter'
};
var request = {
requestId: 'asdfasdfa',
sessionId: 'asdfasdfasdf',
userName: 'Jeremy',
password:'123',
request: requestStr
};
//调用了jquery.json 库
var encoded = $.toJSON( request );
var jsonStr = encoded;
var actionStr = $("#actionPath").val();
$.ajax({
url : actionStr,
type : 'POST',
data : jsonStr,
dataType : 'json',
contentType : 'application/json',
success : function(data, status, xhr) {
console.log(data.RetMessage);
$.each(data.Info, function(index){
$("#result").append("<br>* " + data.Info[index]);
});
$("#result").append("<hr>");
},
Error : function(xhr, error, exception) {
alert(exception.toString());
}
});
}

</script>
</head>
<body style="font-size: 12px; font-family: Tahoma">
<!-- Send JSON -->
<B>Action Path: </B>
<input id="actionPath" type="text" style="width: 300px;" value="json.js"/>
<button class="button" id="buttonUpload" style="margin-left:10px;" onclick="return sendJson();">Send</button>
<div id="result" >result: </div>


进度:100% 返回程序猿

解决织梦图集中上传图片时跳出302错误

图片新热点

导航


目录


    站内搜索
    首页 | W3C | ME