欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2018年12月26日 08:32:47   作者:hedeqiang  
這篇文章主要介紹了Yii2.0 RESTful API 基礎(chǔ)配置教程,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

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

安裝yii2.0

安裝 Composer 后,您可以通過在 Web 可訪問的文件夾下運(yùn)行以下命令來 安裝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ù)庫連接屬性

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

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

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

./yii migrate

拷貝backend目錄,命名為api

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

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

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

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

打開commonconfigbootstrap.php添加以下別名

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

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

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

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

接下來打開 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ī)則

打開 apiconfigmain.php 修改 components屬性,添加下列代碼:

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

...

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

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

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

如何訪問呢

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

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

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

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

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

你說我就是不想加上s,我就想采用http://localhost/user 這種方式來進(jìn)行訪問,好吧,可以,滿足你,只是不推薦

繼續(xù)打開配置文件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,在控制器中我們沒有寫任何一句代碼,他就給我們生成許多方法,但是有時(shí)候我們可能需要修改一些代碼,來達(dá)到我們想要的效果,比如連表查詢,然后再返回?cái)?shù)據(jù)

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

打開剛才新建的user控制器, 重寫 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()
  {
    //你的代碼
  }
  
}

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

我們?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ù)邏輯
  }
  
}

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

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

修改 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'
    ],
    ],
  ],
]

接下來重新訪問就沒有問題了,ps:你自己編寫的任何 action 都要在 extraPatterns 進(jìn)行配置

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

相關(guān)文章

  • Session 失效的原因匯總及解決丟失辦法

    Session 失效的原因匯總及解決丟失辦法

    這篇文章主要介紹了Session 失效的原因匯總的相關(guān)資料,需要的朋友可以參考下
    2015-09-09
  • php中PDO方式實(shí)現(xiàn)數(shù)據(jù)庫的增刪改查

    php中PDO方式實(shí)現(xiàn)數(shù)據(jù)庫的增刪改查

    PDO是mysql數(shù)據(jù)庫操作的一個(gè)公用類了,我們不需要進(jìn)行自定類就可以直接使用pdo來操作數(shù)據(jù)庫了,但是在php默認(rèn)配置中pdo是未開啟所以我們必須先在php.ini中開啟它才可以使用。
    2015-05-05
  • PHP之圖片上傳類實(shí)例代碼(加了縮略圖)

    PHP之圖片上傳類實(shí)例代碼(加了縮略圖)

    下面小編就為大家?guī)硪黄狿HP之圖片上傳類實(shí)例代碼(加了縮略圖)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-06-06
  • php生成二維碼

    php生成二維碼

    隨著科技的發(fā)展,二維碼無處不在,特別是在智能手機(jī)時(shí)代二維碼更活躍,下面小編通過兩種方法給大家介紹利用php生成二維碼,需要的朋友可以參考下
    2015-08-08
  • Laravel框架中集成MongoDB和使用詳解

    Laravel框架中集成MongoDB和使用詳解

    今天小編就為大家分享一篇Laravel框架中集成MongoDB和使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • 淺談PHP鏈表數(shù)據(jù)結(jié)構(gòu)(單鏈表)

    淺談PHP鏈表數(shù)據(jù)結(jié)構(gòu)(單鏈表)

    下面小編就為大家?guī)硪黄獪\談PHP鏈表數(shù)據(jù)結(jié)構(gòu)(單鏈表)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-06-06
  • PHP微信開發(fā)之查詢城市天氣

    PHP微信開發(fā)之查詢城市天氣

    這篇文章主要為大家詳細(xì)介紹了PHP微信開發(fā)之簡(jiǎn)單實(shí)現(xiàn)查詢城市天氣的相關(guān)資料,感興趣的小伙伴們可以參考一下
    2016-06-06
  • thinkphp實(shí)現(xiàn)數(shù)組分頁示例

    thinkphp實(shí)現(xiàn)數(shù)組分頁示例

    這篇文章主要介紹了thinkphp實(shí)現(xiàn)數(shù)組分頁示例,需要的朋友可以參考下
    2014-04-04
  • PHP遠(yuǎn)程采集圖片詳細(xì)教程

    PHP遠(yuǎn)程采集圖片詳細(xì)教程

    這篇文章主要介紹了PHP遠(yuǎn)程采集圖片詳細(xì)教程,一步一步實(shí)現(xiàn)圖片的采集功能,簡(jiǎn)單的入門教程,需要的朋友可以參考下
    2014-07-07
  • Win7環(huán)境下Apache連接MySQL提示連接已重置的解決辦法

    Win7環(huán)境下Apache連接MySQL提示連接已重置的解決辦法

    這篇文章主要為大家詳細(xì)介紹了Win7環(huán)境下Apache連接MySQL提示“連接已重置”的解決辦法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05

最新評(píng)論