濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > Yii2.0 RESTful API 基礎(chǔ)配置教程詳解

Yii2.0 RESTful API 基礎(chǔ)配置教程詳解

熱門(mén)標(biāo)簽:地圖標(biāo)注怎么做商戶(hù)驗(yàn)證 400 電話(huà) 辦理 海南外呼系統(tǒng)方案 蘇州外呼系統(tǒng)有效果嗎 打開(kāi)百度地圖標(biāo)注 兼職做地圖標(biāo)注好賺錢(qián)嗎 智能電銷(xiāo)語(yǔ)音機(jī)器人資訊 山東電銷(xiāo)卡外呼系統(tǒng)原理是什么 亳州企業(yè)外呼系統(tǒng)

最近在做Yii2.0 RESTful API功能,找了好久的資料,才找到這類(lèi)的教程,感謝該作者,以下內(nèi)容根據(jù)我的項(xiàng)目實(shí)際情況做了一定的修改。

安裝yii2.0

安裝 Composer 后,您可以通過(guò)在 Web 可訪(fǎng)問(wèn)的文件夾下運(yùn)行以下命令來(lái) 安裝Yii應(yīng)用程序模板:

composer create-project --prefer-dist yiisoft/yii2-app-basic basic

初始化高級(jí)模板

cd advanced
./init

輸入"./init"后會(huì)出現(xiàn)以下內(nèi)容

Yii Application Initialization Tool v1.0

Which environment do you want the application to be initialized in?

  [0] Development
  [1] Production

  Your choice [0-1, or "q" to quit] 0

  Initialize the application under 'Development' environment? [yes|no] yes

  Start initialization ...

修改數(shù)據(jù)庫(kù)連接屬性

打開(kāi) commonconfigmain-local.php,配置數(shù)據(jù)庫(kù)連接信息

'db' => [
      'class' => 'yii\db\Connection',
      'dsn' => 'mysql:host=127.0.0.1;dbname=yii',
      'username' => 'root',
      'password' => 'root',
      'charset' => 'utf8',
    ],

執(zhí)行 migrate 數(shù)據(jù)庫(kù)遷移

./yii migrate

拷貝backend目錄,命名為api

打開(kāi)apiconfigmain.php 修改id,controllerNamespace等,將所有backend替換為api:

return [
  'id' => 'app-api',
  'basePath' => dirname(__DIR__),
  'controllerNamespace' => 'api\controllers',
]

打開(kāi)apiconfigmain.php開(kāi)啟url路由美化規(guī)則

'urlManager' => [
      'enablePrettyUrl' => true,
      'showScriptName' => false,
      'rules' => [
      ],
    ],

打開(kāi)commonconfigbootstrap.php添加以下別名

Yii::setAlias('@api', dirname(dirname(__DIR__)) . '/api');

為什么要單獨(dú)創(chuàng)建API應(yīng)用

單獨(dú)創(chuàng)建API應(yīng)用,目的是便于維護(hù),可以避免以下問(wèn)題

  • 配置的沖突
  • 控制器的命名不便
  • url美化規(guī)則沖突
  • 分工明確frontend為前臺(tái)目錄;backend為后臺(tái)目錄;api為api目錄

接下來(lái)打開(kāi) apicontrollers 新建一個(gè)User控制器,繼承 yiirestActiveController,命名為 UserController,代碼如下:

?php
namespace api\controllers;
use yii\rest\ActiveController;

class UserController extends ActiveController
{
  public $modelClass = 'common\models\User';
  
}

配置URL規(guī)則

為剛才的 user控制器添加url美化規(guī)則

打開(kāi) apiconfigmain.php 修改 components屬性,添加下列代碼:

...
'urlManager' => [
  'enablePrettyUrl' => true,
  'enableStrictParsing' => true,
  'showScriptName' => false,
  'rules' => [
    ['class' => 'yii\rest\UrlRule', 
    'controller' => 'user'
    ],
  ],
]

...

ok,到此就成了一個(gè) 符合 RESTful 風(fēng)格的API

看起來(lái)在控制器了什么也沒(méi)有寫(xiě),只是指定了一個(gè)模型,但是她的背后完成了很多的功能哦,列表如下:

  • GET /users: 逐頁(yè)列出所有用戶(hù)
  • HEAD /users: 顯示用戶(hù)列表的概要信息
  • POST /users: 創(chuàng)建一個(gè)新用戶(hù)
  • GET /users/123: 返回用戶(hù) 123 的詳細(xì)信息
  • HEAD /users/123: 顯示用戶(hù) 123 的概述信息
  • PATCH /users/123: and PUT /users/123: 更新用戶(hù)123
  • DELETE /users/123: 刪除用戶(hù)123
  • OPTIONS /users: 顯示關(guān)于末端 /users 支持的動(dòng)詞
  • OPTIONS /users/123: 顯示有關(guān)末端 /users/123 支持的動(dòng)詞

如何訪(fǎng)問(wèn)呢

你可以使用 curl命令進(jìn)行訪(fǎng)問(wèn),命令如下:

curl -i -H "Accept:application/json" http://localhost/users

命令行下還是比較麻煩的,也不方便測(cè)試,推薦使用 API測(cè)試工具

這類(lèi)的工具有很多,我就不一一列舉了,這里推薦 Postman,很好很強(qiáng)大,Chorme也有插件,可以安裝,這里我推薦直接下載軟件安裝調(diào)試,比較方便

你可能發(fā)現(xiàn)了 訪(fǎng)問(wèn)任何路由地址都是加的s,users , 為什么呢? 資源,你要理解 資源二字,既然是資源肯定是個(gè)集合,肯定有一大堆,所以要加上復(fù)數(shù),我是這么理解的。

你說(shuō)我就是不想加上s,我就想采用http://localhost/user 這種方式來(lái)進(jìn)行訪(fǎng)問(wèn),好吧,可以,滿(mǎn)足你,只是不推薦

繼續(xù)打開(kāi)配置文件apiconfigmain.php修改剛才添加的 urlManager 如下:

'urlManager' => [
  'enablePrettyUrl' => true,
  'enableStrictParsing' => true,
  'showScriptName' => false,
  'rules' => [
    ['class' => 'yii\rest\UrlRule', 
    'controller' => 'user',
    'pluralize' => false,  //設(shè)置為false 就可以去掉復(fù)數(shù)形式了
    ],
  ],
]

加入 'pluralize' => false, 就表示去掉復(fù)數(shù)形式了,再次強(qiáng)調(diào)不推薦

ok,在控制器中我們沒(méi)有寫(xiě)任何一句代碼,他就給我們生成許多方法,但是有時(shí)候我們可能需要修改一些代碼,來(lái)達(dá)到我們想要的效果,比如連表查詢(xún),然后再返回?cái)?shù)據(jù)

接下來(lái)我們就實(shí)現(xiàn)這樣的功能:

打開(kāi)剛才新建的user控制器, 重寫(xiě) action方法:

?php

namespace api\controllers;
use yii\rest\ActiveController;

class UserController extend extends ActiveController
{
  public $modelClass = 'common\models\User';
  
  public function actions()
  {
    $action= parent::actions(); // TODO: Change the autogenerated stub
    unset($action['index']);
    unset($action['create']);
    unset($action['update']);
    unset($action['delete']);
  }
  
  public function actionIndex()
  {
    //你的代碼
  }
  
}

這樣我們就可以重寫(xiě)他的代碼了。哈哈

我們?cè)傩陆ㄒ粋€(gè)自己的 action

?php

namespace api\controllers;
use yii\rest\ActiveController;

class UserController extends ActiveController
{
  public $modelClass = 'common\models\User';
  
  public function actions()
  {
    $action= parent::actions(); // TODO: Change the autogenerated stub
    unset($action['index']);
    unset($action['create']);
    unset($action['update']);
    unset($action['delete']);
  }
  
  public function actionIndex()
  {
    //你的代碼
  }
  
  public function actionTest() //假如是get請(qǐng)求
  {
    //業(yè)務(wù)邏輯
  }
  
}

然后試著訪(fǎng)問(wèn)一下 http://localhost/users/test,報(bào)錯(cuò)?找不到?

報(bào)錯(cuò)就對(duì)了,那是因?yàn)槲覀儧](méi)有設(shè)置其他路由訪(fǎng)問(wèn)

修改 apiconfigmain.php

'urlManager' => [
  'enablePrettyUrl' => true,
  'enableStrictParsing' => true,
  'showScriptName' => false,
  'rules' => [
    ['class' => 'yii\rest\UrlRule', 
    'controller' => 'user',
    //'pluralize' => false,  //設(shè)置為false 就可以去掉復(fù)數(shù)形式了
    'extraPatterns'=>[
      'GET send-email'=>'test'
    ],
    ],
  ],
]

接下來(lái)重新訪(fǎng)問(wèn)就沒(méi)有問(wèn)題了,ps:你自己編寫(xiě)的任何 action 都要在 extraPatterns 進(jìn)行配置

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 關(guān)于Yii中模型場(chǎng)景的一些簡(jiǎn)單介紹
  • Yii2中的場(chǎng)景(scenario)和驗(yàn)證規(guī)則(rule)詳解
  • Yii2中簡(jiǎn)單的場(chǎng)景使用介紹
  • Yii 2.0中場(chǎng)景的使用教程
  • Yii2.0框架behaviors方法使用實(shí)例分析
  • yii2.0框架使用 beforeAction 防非法登陸的方法分析
  • YII2.0框架行為(Behavior)深入詳解
  • Yii2.0框架實(shí)現(xiàn)帶分頁(yè)的多條件搜索功能示例
  • 修改yii2.0用戶(hù)登錄使用的user表為其它的表實(shí)現(xiàn)方法(推薦)
  • yii2.0框架場(chǎng)景的簡(jiǎn)單使用示例

標(biāo)簽:萊蕪 金華 溫州 綏化 安康 呼倫貝爾 紹興 清遠(yuǎn)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Yii2.0 RESTful API 基礎(chǔ)配置教程詳解》,本文關(guān)鍵詞  Yii2.0,RESTful,API,基礎(chǔ),配置,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Yii2.0 RESTful API 基礎(chǔ)配置教程詳解》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Yii2.0 RESTful API 基礎(chǔ)配置教程詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    吴桥县| 来宾市| 夏河县| 锡林浩特市| 阳新县| 韶关市| 肃宁县| 沙雅县| 施秉县| 高唐县| 青川县| 赤城县| 甘孜县| 徐闻县| 肥乡县| 夹江县| 达尔| 会昌县| 耒阳市| 富川| 乐清市| 佛坪县| 大化| 普兰县| 湾仔区| 陈巴尔虎旗| 兰坪| 延庆县| 文山县| 资中县| 津市市| 遂川县| 濉溪县| 高安市| 两当县| 天柱县| 昌平区| 瑞金市| 澄迈县| 三穗县| 潼南县|