>[danger]### 在官方不久前宣布提供統一API接口服務之后,`SDK`接口現在也已經正式發布了`1.0`版本。
## `ThinkAPI`服務介紹
開發者經常為了各種功能而四處尋找是否有相應的API接口,即便找到了可能還要忍受第三方各種奇葩的SDK調用,或者不支持`composer`安裝。
>[danger]### `ThinkAPI`統一`API`接口服務是由官方聯合合作伙伴封裝的一套接口調用服務及`SDK`,旨在幫助`ThinkPHP`開發者更方便的調用官方及第三方的提供的各類`API`接口及服務,從而更好的構建開發者生態。
### 一站式接口服務
`ThinkAPI`提供了一站式的接口服務,從接口購買、調用到SDK封裝都只需要一個官方賬號即可完成,無需注冊各種接口服務賬號,除了涵蓋常用`API`服務之外,還設計了可轉換接口服務更好的保障接口的穩定性,讓你省心省力。
### 提供統一的`SDK`
官方提供了一套統一的`SDK for PHP`調用服務,通過`composer`安裝一個輕量級的依賴包即可調用,采用簡潔和現代化的調用方式,并且對IDE友好,可以簡化你的`API`調用開發工作。
### 官方服務市場保障
`ThinkAPI`所有支持的接口都納入[官方服務市場](https://www.thinkphp.cn/partner/78),包括免費接口和付費接口,市場服務有保障,并且有購買記錄以及統計數據。
對于一些付費的接口,官方的[服務市場](https://www.thinkphp.cn/partner/78)提供了更優惠的價格。
## `ThinkAPI`調用流程
請務必按照如下流程進行`ThinkAPI`接口服務調用:
* 第一步:注冊[服務市場賬號](https://market.topthink.com/auth/login)獲取個人`AppCode`;
* 第二步:購買[接口服務(次數)](https://market.topthink.com/partner/78),免費接口則跳過;
* 第三步:通過接口地址(及參數)或者`SDK`調用接口服務返回數據;
## 身份認證(AppCode)
無論是免費還是付費接口,都需要通過`AppCode`授權后才能進行接口請求。`AppCode`的值可以在官方服務市場`->`個人中心`->`[API管理](https://market.topthink.com/setting/api)的上方查詢到,每個用戶賬號擁有一個唯一的`AppCode`值(請不要隨意泄露)。

可以使用兩種方法進行身份認證:
### 第一種:`Header`信息認證(推薦)
在請求`Header`中添加的`Authorization`字段,配置值為“AppCode + 半角空格 +AppCode值”。
格式如下:
~~~
Authorization:AppCode AppCode值
~~~
### 第二種:請求參數認證
請求Query中添加的`appCode`參數,參數的值為用戶`AppCode`的值。
~~~
https://API接口地址?appCode=AppCode值
~~~
## 原生`API`調用
`ThinkAPI`所有支持的接口服務都有一個唯一的接口調用地址,這個接口地址統一使用`https://api.topthink.com` 作為接口網址,例如身份證查詢接口的請求地址是:
```
https://api.topthink.com/idcard/index
```
你可以通過下面的請求來調用接口
```
https://api.topthink.com/idcard/index?appCode=AppCode值&cardno=要查詢的身份證號碼
```
你可以在注冊市場賬號后測試下這個免費接口,查看具體的返回數據。
>[danger]注意:部分接口可能采用不同的請求類型,不一定是`GET`請求,具體的接口參數請參考具體的API文檔,會有詳細的說明。
### 返回數據格式
所有的`api`接口返回數據規范如下:
| 名稱 | 類型 | 說明 |
| --- | --- | --- |
| code | int | 返回碼,0 表示成功 其它表示失敗 |
| message | string | 返回提示信息 |
| data | object | 返回數據 |
>[danger] 當`code`為0的時候計費,其中`data`包含的數據和具體的接口有關。
## 使用`SDK`調用
除了使用原生的方式調用接口外,`ThinkAPI`還提供了一套通用的`SDK`接口規范,讓你用更簡潔和現代化的方式調用接口服務。使用方法如下:
首先需要在你的項目里面安裝`think-api`庫
~~~
composer require topthink/think-api
~~~
> 建議設置使用[阿里云 Composer 全量鏡像](https://developer.aliyun.com/composer)
然后就可以調用你需要的接口進行查詢和返回數據,還是以上面的查詢身份證所屬地區接口為例說明:
~~~
use think\api\Client;
// API調用之前必須設置`AppCode`值,用于接口調用的身份認證
$client = new Client("YourAppCode");
// 調用某個接口方法和傳入參數
$result = $client->idcardIndex()
->withCardno('身份證號碼')
->request();
var_dump($result);
~~~
所有的接口服務和方法都支持IDE自動提示和完成(請務必注意方法大小寫必須保持一致 確保參數名的正確性),基本上不需要文檔即可完成接口開發工作。
上面是免費接口的SDK調用示例,付費接口的調用方式是完全一樣的,區別在于付費接口你必須要先在市場購買接口次數才能正常調用(`ThinkAPI`服務的接口必須在[官方市場](https://market.topthink.com/partner/78)購買才有效,第三方購買的接口是不支持調用的),而免費接口則有每天不超過100次請求的限制。
下面是身份證實名認證的付費接口調用示例:
```
$client = new Client("YourAppCode");
$result = $client->idcardQuery()
->withIdcard('身份證號碼')
->withRealname('姓名')
->request();
var_dump($result);
```
> 注意,該SDK服務僅支持官方已經接入的API接口,目前接口數量正在擴充中,你可以聯系我們反饋你需要的API接口,我們來統一進行接入。
## 成為`API`供應商
面向服務開發將是將來的一大開發趨勢,如果你計劃在100萬+的ThinkPHP開發者中推廣你們的服務,歡迎聯系!誠邀合作伙伴(包括但不限于API服務商或對外提供開放API的產品服務商)加入官方統一API接口服務計劃。
## 聯系我們
成為API供應商或者反饋你需要的API接口請聯系微信`topthink`(注明來意)。
- 值得升級到5.1的18個理由
- 5.1.7版本新特性
- JSON字段類型在ORM中的使用
- 文件下載響應對象
- 教你使用5.1的數組對象查詢
- 模型三大利器之一:搜索器
- 在ThinkPHP中使用Yaconf
- 掌握命令行的表格輸出
- 5.1.25查詢參數綁定的改進
- ThinkPHP安全規范指引
- 巧用數據集的排序功能實現統計排序
- think-orm ——基于5.1的獨立ORM庫
- think-template——基于ThinkPHP的獨立模板引擎
- ThinkPHP5.1.26版本發布——修正版本,包含安全更新
- ThinkPHP5.0和3.2再發安全更新
- 官宣:ThinkPHP發布首個LTS版本
- 你真的了解Db類和模型的正確使用姿勢么?
- 如何更有效的記錄和管理日志
- 模型三大利器之二:修改器
- ThinkPHP5.1.28版本發布——修正上一版本問題,改進關聯查詢
- 模型三大利器之三:獲取器
- API版本控制的幾種思路
- ThinkPHP5.2第一個Beta版本發布測試
- 讓你少犯錯的數據查詢基本原則
- ThinkPHP發布5.1.29版本——常規更新
- 這15個好習慣讓你更容易升級到5.2
- 如何有效提高ThinkPHP的應用性能
- 讓你提高開發效率的查詢技巧
- 模型關聯查詢不完全指南
- 5.2發布Beta2版本——統一和精簡大量用法
- ThinkPHP發布5.1.30版本——支持微秒時間字段寫入
- ThinkPHP的數據緩存使用
- ThinkPHP5.2安裝及入口文件
- ThinkPHP榮獲2018 年度最受歡迎中國開源開發框架第1名
- 5.1路由使用心得技巧
- ThinkPHP5.*版本發布安全更新
- ThinkPHP項目及代碼規范指北
- 5.2版本的設計規范指導
- ThinkPHP5.1.32版本發布——圣誕快樂
- 利用Trait特性給模型增加樂觀鎖功能
- 5.2數據庫和模型的變化(摘要)
- ThinkPHP模板引擎實現和常見問題
- ThinkPHP5.0.24版本發布——安全更新
- 不忘初心,方得始終——ThinkPHP十三周年報告
- ThinkPHP5+相關資源匯總
- 異步社區ThinkPHP周年慶專享優惠活動
- 5.2路由的調整和改進
- ThinkPHP發布5.1.33版本——包含安全更新
- ThinkPHP擴展開發指南
- ThinkPHP發布5.2Beta3版本
- ThinkPHP發布5.1.34版本——喜迎新年
- ThinkPHP發布5.2RC1版本
- ThinkPHP發布5.1.35版本——常規更新
- 5.2配置類的調整
- 5.2時間查詢的改進和優化
- 5.2RC版本升級不完全指導(僅供學習參考)
- ThinkPHP5.2版本正式變更為6.0版本
- ThinkPHP百度云云虛擬主機專享免費活動
- 事件系統以及查詢事件、模型事件的使用
- ThinkPHP6.0RC2版本發布——架構升級、精簡核心
- ThinkPHP5.1.36LTS版本發布——常規更新
- 新版Session和Cookie設計變化
- ThinkPHP5.1.37版本發布——常規更新
- ThinkPHP6.0RC3版本發布——細節完善,體驗優化
- 6.0中間件使用詳解
- Composer各大廠商鏡像地址
- ThinkPHP6.0發布計劃公告
- 「ThinkPHP開發者周刊」招募志愿者
- ThinkPHP6.0日志變化
- ThinkPHP5.1.38版本發布——常規更新
- ThinkPHP6.0RC4版本發布——ORM獨立,日志多通道支持
- ThinkORM2.0開發指南上線
- ThinkPHP6.0RC5版本發布——多應用模式獨立,中間件機制調整
- ThinkPHP6.0版本發布——程序員節福利
- ThinkPHP5.1.39LTS版本發布——常規更新
- ThinkPHP6.0.1版本發布——圣誕快樂!
- 回顧2019,展望2020!
- ThinkPHPV6.0.2版本發布——2020新春快樂!
- 周年福利系列:Swoole合作優惠
- 億速云成為ThinkPHPV6.0獨家贊助發布商??
- 新冠疫情工具和限免資源專題(保持更新中)
- 周年福利系列:創宇信用認證合作優惠
- 周年福利系列:碼云企業版限時10%優惠
- 周年福利系列:想天短說抵現優惠
- think-swoole直播:從零開始掌握swoole開發
- 周年福利系列:B2C開源電商ShopXO授權8折優惠
- 周年福利系列:LayuiAdmin 永久授權限時優惠
- ThinkPHP資源導航站上線——構建生態 服務未來
- ThinkPHP官方技術支持服務和應用服務市場上線公測
- ThinkPHP市場精選——推廣基本要素
- ThinkPHP市場精選——客服聊天專題
- ThinkPHPV6.0.3版本發布——端午安康
- ThinkPHP開發者扶持計劃
- 6.0.3版本關鍵更新及升級事項
- 「ThinkPHP開發者周刊」改版重啟
- ThinkPHP市場精選——企業建站專題
- ThinkPHP 提供統一API接口服務
- ThinkPHP市場精選——直播電商專題
- ThinkAPI服務SDK發布
- 官方服務市場啟用獨立子域名
- ThinkPHP市場精選——刷臉支付專題
- ThinkAPI推出會員服務計劃
- ThinkPHPV6.0.4版本發布——中秋國慶雙節快樂
- ThinkPHPV5.1.40版本發布——常規更新
- 1024程序員節福利走一波
- ThinkPHP V6.0.5版本發布——兼容Composer2.0
- 知識圖譜應用場景——源論技術沙龍
- ThinkPHP5.*版本改進Composer2.0的兼容
- 官方市場雙十一精選推薦
- 技術人做產品有機會么(文末送課程)
- 本周秒殺——古德云售后獲客營銷系統
- ThinkAPI服務更新——支持接口分組和PHP版本依賴調整
- PHP8新特性盤點
- PHP8新特性系列:構造器屬性提升使用及注意事項
- ThinkPHP2021新年寄語
- ThinkPHP V6.0.6&V5.1.41版本發布——兼容PHP8.0
- PHP如何更優雅地調用API接口
- ThinkPHP V6.0.7發布——修正版本
- ThinkAPI服務更新——IP白名單
- 最新版ThinkORM對于時間字段的調整
- ThinkAPI短信接口正式上線
- ThinkPHP V6.0.8版本發布——多環境變量配置支持
- 頂想云寫作服務開啟第一次公測
- ThinkSSL上線——官方SSL/TLS證書服務
- MDBootstrap國內用戶福利——ThinkPHP官方市場首發
- ThinkPHP V6.0.9版本發布——常規更新
- ThinkORM功能盤點——虛擬模型
- 全面支持主流GIT版本庫——云寫作服務第二次公測
- 云寫作服務私有化部署方案之:版本庫私有化
- 看云雙十一活動
- ThinkPHP V6.0.10LTS發布——兼容PHP8.1
- ThinkPHP V6.0.12發布——命令行兼容8.1
- 頂想云知識管理上線公測——構建企業文檔中心和知識庫
- 頂想云上線——助力生態數字化建設
- 618活動進行中——官方市場迎來一波更新
- 頂想云知識管理正式上線——看云文檔啟動遷移服務
- ThinkPHP V6.0.13發布——常規更新
- 頂想云網站助理服務上線——構建產品支持服務
- ThinkPHP發布6.1.0&6.0.14版本——安全更新
- ThinkPHP新版社區上線試運營
- ThinkAPI上架人臉核身接口——助力網站實名認證
- 辭舊迎新——舊版社區停止注冊及發帖
- ThinkPHP6.1.2版本發布——兼容PHP8.2