首頁 > CMS教程 > DEDECMS > 主體

dedecms如何寫API介面

發布: 2019-07-31 10:56:28
原創
5820 人瀏覽過

dedecms如何寫API介面

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.&#39;/json.class.php&#39;);
$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.&#39;/json.class.php&#39;);
$reval = array();
$dsql->SetQuery("SELECT id,title FROM `dede_archives` ORDER BY id DESC LIMIT 0,10");
$dsql->Execute(&#39;me&#39;);
while ($row = $dsql->GetArray(&#39;me&#39;)) {
$row[&#39;title&#39;] = gb2utf8($row[&#39;title&#39;]);
$reval[] = $row;
}
$json = new Services_JSON(SERVICES_JSON_SUPPRESS_ERRORS);
echo $json->encode($reval);
?>
登入後複製

這裡程式碼有進行了GBK轉UTF8的操作,所以相容GBK版的DEDECMS

呼叫方法:

{dede:json url=&#39;http://域名/json.php&#39; cache=300}
[field:id/]-[field:title/]<br/>
{/dede:json}
登入後複製

把呼叫程式碼放到你需要的地方就行

cache=300 快取時間,0為不快取

推薦:dedecms使用教學

#

以上是dedecms如何寫API介面的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!