gpt4 book ai didi

DEDECMS JSON数据生成 DEDECMS JSON接口制作

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 29 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章DEDECMS JSON数据生成 DEDECMS JSON接口制作由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

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接口制作的文章就讲到这里了,如果你想了解更多关于DEDECMS JSON数据生成 DEDECMS JSON接口制作的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com