搜尋
首頁CMS教程DEDECMSdedecms如何寫API介面

dedecms如何寫API介面

Jul 31, 2019 am 10:55 AM
dedecmsjson

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中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。