您好,欢迎来到菜鸟吧源码网(www.cniao8.com)本站只做精品网站源码!
  • 首 页
  • 会员介绍
  •  

    当前位置:主页 > 站长学堂 > dedecms教程 >
    DEDECMS JSON数据生成 DEDECMS JSON接口制作
    时间:2020-03-01 11:53 作者:菜鸟吧 浏览:收藏 挑错 打印

    json数据格式可以方便不同站点之间进行数据调用引用,当然我们的DEDECMS也可以实现全站数据生成JSON供其他站点调用,代码很简单,主要用到include/json.class.php。

    织梦本身是自带json标签的,调用方法:

    {dede:json url='http://yoursite/json.php' cache=300}
    [field:id/]-[field:title/]<br/>
    {/dede:json}

     这个标签调用例子在织梦手册里已经给我们提供了,url是一个远程json接口地址,这个接口文件json.php代码 里面,最后的返回必须是把数据通过json_encode($feeds)系统函数,进行json编码后,通过echo或print()函数来打印出来,这二点是必须的,然后,在前台我们就可以通过$.ajax()或$.getjson()来获取数据。织梦系统给我们提供了一个json类,在include/json.class.php文件里面,也就是是说,我们在对php文件转换json编码,就有了二种方法:

     1.直接用php系统给我们提供的系统函数,json_encode(),我建立大家用这个,即简单又省事,既然,php系统给我们提供了,我们可以不用织梦系统提供的。

     2.就是用织梦系统提供的,encode(),在使用前,首先引入json.class.php,即:

      require_once(DEDEINC.'/json.class.php');
      $json = new Services_JSON(SERVICES_JSON_SUPPRESS_ERRORS);

      echo $json->encode($reval);

     $reval这个变量是我们从数据库或其它地方得到的,一般是一个二维数组,例如下:

     Array (
     [0] => Array ( [id] => 95 [title] => 原图设计)
     [1] => Array ( [id] => 113 [title] => ssssssssssss)
     [2] => Array ( [id] => 111 [title] => hjhj )
     [3] => Array ( [id] => 110 [title] => ssssssssssss)
        )

     经echo 以后,显示的内容如下所示。

     [
      {"id":"95","title":"\u539f\u521b"},
      {"id":"113","title":"ssssssssssss"},
      {"id":"111","title":"hjhj"},
      {"id":"110","title":"ssssssssssss"}
     ]

     这是经过encode()或用json_encode()后,显示的内容。即,用中括号括起来的,几个json数据,这个数据回给请求的$.ajax()或$.getjson(),并由其对这个数据进行处理,显示我们相要的结果。

    知道了原理,接下来就是详细实现方法,如下:

    首先新建一个PHP文件,命名为json.php(也可以新建个文件夹命名为api,然后PHP命名为index.php,这样调用的时候就只需要http://你的域名/api这样的方式调用),用于作为被调用的API接口,代码如下:

    <?php

    $cfg_NotPrintHead = false;

    header("Content-Type: text/html; charset=utf-8");

    include_once (dirname(__FILE__)."/../include/common.inc.php");

    error_reporting(E_ALL || ~E_NOTICE);

    require_once(DEDEINC.'/json.class.php');

    $reval = array();

    $dsql->SetQuery("SELECT id,title FROM `dede_archives` ORDER BY id DESC LIMIT 0,10");

    $dsql->Execute('me');

    while ($row = $dsql->GetArray('me')) {

    $row['title'] = gb2utf8($row['title']);

    $reval[] = $row;

    }

    $json = new Services_JSON(SERVICES_JSON_SUPPRESS_ERRORS);

    echo $json->encode($reval);

    ?>

    这里代码有进行了GBK转UTF8的操作,所以兼容GBK版的DEDECMS

    调用方法:

    {dede:json url='http://域名/json.php' cache=300}

    [field:id/]-[field:title/]<br/>

    {/dede:json}

    把调用代码放到你你需要的地方就行

    cache=300 缓存时间,0为不缓存

  • 本文标题:DEDECMS JSON数据生成 DEDECMS JSON接口制作
  • 本文地址:https://www.cniao8.com/11170.html

    上一篇:织梦DedeCMS禁止调用隐藏栏目下文章的开发方法

    下一篇:DEDECMS批量导入excel数据到后台文章系统的开发教程

  • 郑重声明:
    本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,不存在任何商业目的与商业用途。 若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
    我们不承担任何技术及版权问题,且不对任何资源负法律责任。
    如无法下载,联系站长索要。
    如有侵犯您的版权,请给我们来信:admin@cniao8.com,我们尽快处理。

    织梦系统解决后台“DEDECMS安全提示”的方法织梦系统解决后台“DEDECMS安全提示”
    织梦(DEDECMS)系统GBK和UTF8版本的区分(选择方法)织梦(DEDECMS)系统GBK和UTF8版本的区
    DEDECMS自动锚文本设置方法、教程、详解DEDECMS自动锚文本设置方法、教程、详