> php教程 > php手册 > php返回json数据函数例子

php返回json数据函数例子

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-05-25 16:45:57
원래의
1274명이 탐색했습니다.

json_encode()函数是一个在php中可以把数组转换成json格式的函数了,但json_encode函数对于英文是没有任何问题,如果碰到中文或编码有不致情况时会出现中文转换之后变空了,下面我就来从多方面来介绍php返回json数据应用与一些使用转换时的问题解决办法。

json_encode()函数用法。

1

echo json_encode(array('a'=>'bbbb','c'=>'ddddd');

로그인 후 복사

这样就会生成一个标准的json格式的数据

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

<?php

//需要执行的SQL语句

//单条

$sql="select id,name from tbl_user where id=1";

//多条数据

//$sql="select id,name from tbl_user";

//调用conn.php文件进行数据库操作

require(&#39;Conn.php&#39;);

//提示操作成功信息,注意:$result存在于conn.php文件中,被调用出来

if($result)

{

// $array=mysql_fetch_array($result,MYSQL_ASSOC);

  

   

 /*数据集

 $users=array();

 $i=0;

 while($row=mysql_fetch_array($result,MYSQL_ASSOC)){

   echo $row[&#39;id&#39;].&#39;-----------&#39;.$row[&#39;name&#39;].&#39;</br>&#39;;

   $users[$i]=$row;

   $i++;

 }

  echo json_encode(array(&#39;dataList&#39;=>$users));

 */

 /*单条数据*/

 $row=mysql_fetch_row($result,MYSQL_ASSOC);

  

 echo json_encode(array(&#39;jsonObj&#39;=>$row));

}

mysql_free_result($result);

//释放结果

mysql_close();

//关闭连接

?>

로그인 후 복사

上面是数据库生成json数据了

单条数据:{"jsonObj":{"id":"1","name":"lmw"}}

多条数据:{"dataList":[{"id":"1","name":"lmw"},{"id":"2","name":"xxj"},{"id":"3","name":"xxxj"}]}


现在很多情况下,我们需要程序返回一个Json格式的结果,比如:

1

2

3

4

5

6

{

    "UserKeyGetResponse":

        {"RequestName":"e99e6d63e8c712d7699f52978a","api_key_value":"41954dd9b1cb6a95802eab6810"},

    "error_response":

        {"code":"NO_ERROR","msg":"获取系统参数成功"}

}

로그인 후 복사

可以将结果写成这样的数组形式:

1

2

$respon = array(&#39;UserKeyGetResponse&#39; => array(&#39;RequestName&#39; => $api_request_name, &#39;api_key_value&#39; => $api_key_value),

&#39;error_response&#39; => array(&#39;code&#39; => &#39;NO_ERROR&#39;, &#39;msg&#39; => &#39;获取系统参数成功&#39;));

로그인 후 복사

代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<?php

function arrayRecursive(&$array, $function, $apply_to_keys_also = false)

{

    static $recursive_counter = 0;

    if (++$recursive_counter > 1000) {

        die(&#39;possible deep recursion attack&#39;);

    }

    foreach ($array as $key => $value) {

        if (is_array($value)) {

            arrayRecursive($array[$key], $function, $apply_to_keys_also);

        } else {

            $array[$key] = $function($value);

        }

        if ($apply_to_keys_also && is_string($key)) {

            $new_key = $function($key);

            if ($new_key != $key) {

                $array[$new_key] = $array[$key];

                unset($array[$key]);

            }

        }

    }

    $recursive_counter--;

}

?>

로그인 후 복사

g:

1

2

3

4

<?php

$error_respon = array(&#39;code&#39; => &#39;ERROR_MSG_MISS&#39;, &#39;msg&#39; => &#39;消息不存在&#39;);

echo JSON($array);

?>

로그인 후 복사

结果为:

1

{"code":"ERROR_MSG_MISS","msg":"消息不存在"}

로그인 후 복사

客户端就可以解析这个结果了,当然错误码要用数字代替。

这样就好多了我们显示的直接是中文了,当然显示那个16进制的编码也是没有问题的哦。


本文链接:

收藏随意^^请保留教程地址.

관련 라벨:
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
foreach 문제
에서 1970-01-01 08:00:00
0
0
0
루프 문제, foreach
에서 1970-01-01 08:00:00
0
0
0
if 및 foreach 깨기
에서 1970-01-01 08:00:00
0
0
0
Laravel updateOrInsert 처리 foreach
에서 1970-01-01 08:00:00
0
0
0
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿