class Emp { public $name = ""; public $hobbies = ""; public $birthdate = ""; } $e = new Emp(); $e->name = "sachin"; $e->hobbies = "sports"; $e->birthdate = date('m/d/Y h:i:s a', "8/5/1974 12:20:03 p"); $e->birthdate = date('m/d/Y h:i:s a', strtotime("8/5/1974 12:20:03")); echo json_encode($e); ?> 在执行过程中,这将产生以下结果: {"name":"sachin","hobbies":"sports","birthdate":"08/05/1974 12:20:03 pm"} 解码JSON在PHP(json_decode)PHP json_decode()函数用于解码JSON在PHP。这个函数返回值从json解码成适当的 PHP类型。 语法: mixed json_decode ($json [,$assoc = false [, $depth = 512 [, $options = 0 ]]])参数: json_string: 它必须是UTF-8编码的数据编码的字符串 assoc: 这是一个布尔类型参数设置为TRUE时,返回的对象将被转换成关联数组 depth: 它是一个整数类型的参数,它指定递归深度 options: 它是一个整数类型的位掩码JSON解码,支持JSON_BIGINT_AS_STRING 例子 下面的示例显示了如何可以使用PHP来解码JSON对象:
代码如下 | 复制代码 | $json = '{"a":1,"b":2,"c":3,"d":4,"e":5}'; var_dump(json_decode($json)); var_dump(json_decode($json, true)); ?> 在执行过程中,这将产生以下结果: object(stdClass)#1 (5) { ["a"] => int(1) ["b"] => int(2) ["c"] => int(3) ["d"] => int(4) ["e"] => int(5) } array(5) { ["a"] => int(1) ["b"] => int(2) ["c"] => int(3) ["d"] => int(4) ["e"] => int(5) } 假如我们获取的JSON数据如下:(可以使用curl、fsockopen等方式获取)
代码如下 | 复制代码 | { "translation":["Hello world"], "query":"你好世界", "errorCode":0, "web":[ { "value":["hello world"], "key":"你好世界" }, { "value":["Hello World"], "key":"世界你好" } ] } 用json_decode函数返回array的方式得到: Array ( [translation] => Array ( [0] => Hello world ) [query] => 你好世界 [errorCode] => 0 [web] => Array ( [0] => Array ( [value] => Array ( [0] => hello world ) [key] => 你好世界 ) [1] => Array ( [value] => Array ( [0] => Hello World ) [key] => 世界你好 ) ) ) 我们在PHP语言中可以用以下方法取得我们想要的值:
代码如下 | 复制代码 | /*---------------------------------- $data = ' { "translation":["Hello world"], "query":"你好世界", "errorCode":0, "web":[ { "value":["hello world"], "key":"你好世界" }, { "value":["Hello World"], "key":"世界你好" } ] } '; -------------------------------------*/ $data = << { "translation":["Hello world"], "query":"你好世界", "errorCode":0, "web":[ { "value":["hello world"], "key":"你好世界" }, { "value":["Hello World"], "key":"世界你好" } ] } STR; $jsondata=json_decode($data,true); header("Content-Type: text/html; charset=UTF-8"); //print_r($jsondata); echo " ".$jsondata['translation'][0]; //Hello world echo " ".$jsondata['query']; //你好世界 echo " ".$jsondata['web'][0]['value'][0]; //hello world echo " ".$jsondata['web'][1]['key']; //世界你好 ?> 例,结合数据库操作
代码如下 | 复制代码 | include './include/conn.php'; //数据库链接文件 $sql_notice = mysql_query('SELECT * FROM gg_notice where enable = "1" limit 0,10'); $notice = mysql_fetch_array($sql_notice, MYSQL_ASSOC); print_r ($notice); ?> 第一php网提供的教程--将数据库读取的数据生成json格式请注意两种方法生成的对象数组在结构上的区别echo ' 法一';//假设以下数组是根据我们从数据库读取的数据生成的 $jarr=array('total'=>239,'row'=>array( array('code'=>'001','name'=>'中国www.jquerycn.cn','addr'=>'Address 11','col4'=>'col4 data'), array('code'=>'002','name'=>'Name 2','addr'=>'Address 12','col4'=>'col4 data'), ) ); //法一: $jobj=new stdclass();//实例化stdclass,这是php内置的空类,可以用来传递数据,由于json_decode后的数据是以对象数组的形式存放的, //所以我们生成的时候也要把数据存储在对象中 foreach($jarr as $key=>$value){ $jobj->$key=$value; } print_r($jobj);//打印传递属性后的对象 echo '使用$jobj->row[0]['code']输出数组元素:'.$jobj->row[0]['code'].' '; echo '编码后的json字符串:'.json_encode($jobj).' ';//打印编码后的json字符串 echo '
';//法二: echo ' 法二';echo '编码后的json字符串:'; echo $str=json_encode($jarr);//将数组进行json编码 echo ' '; $arr=json_decode($str);//再进行json解码 print_r($arr);//打印解码后的数组,数据存储在对象数组中 echo '使用$arr->row[0]->code输出数组元素:'.$arr->row[0]->code; ?> |
|
|
|
|