亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

ホームページ PHPフレームワーク YII yii2 で API インターフェースを作成する手順

yii2 で API インターフェースを作成する手順

Nov 06, 2019 pm 05:32 PM
yii2

yii2 で API インターフェースを作成する手順

yii2寫(xiě)api接口步驟

Yii2如何實(shí)現(xiàn)RESTful風(fēng)格的API(推薦:《YII教程》?)

1、建立單獨(dú)的應(yīng)用程序

為了增加程序的可維護(hù)性,易操作性,我們選擇新建一套應(yīng)用程序,這也是為了和前臺(tái)應(yīng)用、后臺(tái)應(yīng)用區(qū)分開(kāi)操作。

在WEB前端(frontend)和后端(backend)的同級(jí)目錄,新建一個(gè)文件夾,命名api,其目錄結(jié)構(gòu)如下所示:

├─assets
│      AppAsset.php
├─config
│      bootstrap.php
│      main-local.php
│      main.php
│      params-local.php
│      params.php
├─runtime
└─web
    │ index.php
    ├─assets
    └─css

可以看出其目錄結(jié)構(gòu)基本上同backend沒(méi)有其他差異,因?yàn)槲覀兙褪强截恇ackend項(xiàng)目,只是做了部分優(yōu)化。

友情提醒,該步驟完成以后,需要修改common\config\bootstrap.php文件,對(duì)新建的應(yīng)用增加alias別名

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

2、為新建的api應(yīng)用程序美化路由

首先保證你的web服務(wù)器開(kāi)啟rewrite規(guī)則,細(xì)節(jié)我們就不說(shuō)了,不過(guò)這是前提。

接著配置api/config/main.php文件

'components' => [
    // other config
    'urlManager' => [
        'enablePrettyUrl' => true,
        'showScriptName' => false,
        'enableStrictParsing' =>true,
        'rules' => [],
    ]
],

開(kāi)啟nginx的rewrite,注意在你的配置文件中加入紅色的文字:

server {
    charset utf-8;
    client_max_body_size 128M;

    listen 80; ## listen for ipv4
    #listen [::]:80 default_server ipv6only=on; ## listen for ipv6

    server_name mysite.local;
    root        /path/to/basic/web;
    index       index.php;

    access_log  /path/to/basic/log/access.log;
    error_log   /path/to/basic/log/error.log;

    location / {
        # Redirect everything that isn't a real file to index.php
        try_files $uri $uri/ /index.php$is_args$args;
    }

    # uncomment to avoid processing of calls to non-existing static files by Yii
    #location ~ \.(js|css|png|jpg|gif|swf|ico|pdf|mov|fla|zip|rar)$ {
    #    try_files $uri =404;
    #}
    #error_page 404 /404.html;

    # deny accessing php files for the /assets directory
    location ~ ^/assets/.*\.php$ {
        deny all;
    }

    location ~ \.php$ {
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_pass 127.0.0.1:9000;
        #fastcgi_pass unix:/var/run/php5-fpm.sock;
        try_files $uri =404;
    }

    location ~* /\. {
        deny all;
    }
}

最后只需要在應(yīng)用入口同級(jí)增加.htaccess文件就好,我們以nginx為例

# use mod_rewrite for pretty URL support
RewriteEngine on
# if a directory or a file exists, use the request directly
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
# otherwise forward the request to index.php
RewriteRule . index.php

3、利用gii生成測(cè)試modules

用了便于演示說(shuō)明,我們新建一張數(shù)據(jù)表goods表,并向其中插入幾條數(shù)據(jù)。

CREATE TABLE `goods` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(100) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

INSERT INTO `goods` VALUES ('1', '11111');
INSERT INTO `goods` VALUES ('2', '22222');
INSERT INTO `goods` VALUES ('3', '333');
INSERT INTO `goods` VALUES ('4', '444');
INSERT INTO `goods` VALUES ('5', '555');

接著我們先利用gii生成modules后,再利用gii模塊,按照下圖中生成goods信息

yii2 で API インターフェースを作成する手順

yii2 で API インターフェースを作成する手順

yii2 で API インターフェースを作成する手順

現(xiàn)在,我們的api目錄結(jié)構(gòu)應(yīng)該多個(gè)下面這幾個(gè)目錄

│
├─models
│      Goods.php
│
├─modules
│  └─v1
│      │  Module.php
│      │
│      ├─controllers
│      │      DefaultController.php
│      │      GoodsController.php
│      │
│      └─views
│          └─default
│                  index.php

需要說(shuō)明的是:在生成modules的步驟中,為了使我們的模塊可以訪問(wèn),不要忘記在main.php配置文件中添加下面的代碼

<?php    
    ......
    &#39;modules&#39; => [
        &#39;v1&#39; => [
            &#39;class&#39; => &#39;api\modules\v1\Module&#39;,
        ],
    ],
    ......

4、重新配置控制器

為了實(shí)現(xiàn)restful風(fēng)格的api,在yii2中,我們需要對(duì)控制器進(jìn)行一下改寫(xiě)

<?php
namespace api\modules\v1\controllers;
use yii\rest\ActiveController;
class GoodsController extends ActiveController
{
    public $modelClass = &#39;api\models\Goods&#39;;
}

5、為Goods配置Url規(guī)則

&#39;rules&#39; => [
    [
        &#39;class&#39; => &#39;yii\rest\UrlRule&#39;,
        &#39;controller&#39; => [&#39;v1/goods&#39;]
    ],
]

6、模擬請(qǐng)求操作

經(jīng)過(guò)上面幾個(gè)步驟,到此我們已經(jīng)為goods成功創(chuàng)建了滿(mǎn)足restful風(fēng)格的api了。為了更好更方便的演示,我們借助工具postman進(jìn)行模擬請(qǐng)求。

為了見(jiàn)證一下我們的操作,我們用postman請(qǐng)求一下GET /v1/goods看看結(jié)果如何:

接著我們先利用gii生成modules后,再利用gii模塊,按照下圖中生成goods信息

yii2 で API インターフェースを作成する手順

現(xiàn)在,我們的api目錄結(jié)構(gòu)應(yīng)該多個(gè)下面這幾個(gè)目錄

從上面截圖中可以清楚的看到,GET /v1/goods 已經(jīng)能夠很方便的獲取我們表中的數(shù)據(jù)了。

當(dāng)然,yii2還對(duì)該api封裝了如下操作:

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)詞

不信的話我們可以利用postman發(fā)送一個(gè)post請(qǐng)求到/v1/goods,我們會(huì)發(fā)現(xiàn)成功創(chuàng)建了一個(gè)新的商品。

需要提醒的是,操作中還請(qǐng)細(xì)心且注意:如果你的控制器末端不是復(fù)數(shù)(比如是blog非blogs)請(qǐng)保證請(qǐng)求的時(shí)候是復(fù)數(shù)!這是因?yàn)樵赗ESTful架構(gòu)中,網(wǎng)址中只能有名詞而不能包含動(dòng)詞,名詞又往往與數(shù)據(jù)表相對(duì)應(yīng),數(shù)據(jù)表呢又是一個(gè)“集合”,因此該名詞往往是復(fù)數(shù)的形式。

7、關(guān)于授權(quán)認(rèn)證

為什么需要授權(quán)認(rèn)證?這在一般的操作中是需要的。比如說(shuō)用戶(hù)要設(shè)置自己的信息。

為了對(duì)yii2 restful授權(quán)認(rèn)證說(shuō)的更清楚,我們將會(huì)以?xún)蓚€(gè)兩種不同的方法進(jìn)行說(shuō)明。

首先需要開(kāi)啟認(rèn)證:

假設(shè)我們已經(jīng)按照第3步創(chuàng)建了包含字段access-token的數(shù)據(jù)表user,而且利用gii上生成了相應(yīng)的model和controller

配置main.php文件

&#39;components&#39; => [
    &#39;user&#39; => [ 
        &#39;identityClass&#39; => &#39;common\models\User&#39;,
        &#39;enableAutoLogin&#39; => true,
        &#39;enableSession&#39;=>false
    ],
],

為控制器配置authenticator行為指定認(rèn)證方式

<?php
namespace api\modules\v1\controllers;
use yii\rest\ActiveController;
use yii\helpers\ArrayHelper;
use yii\filters\auth\QueryParamAuth;
class UserController extends ActiveController
{
    public $modelClass = &#39;api\models\User&#39;;
    public function behaviors() {
        return ArrayHelper::merge (parent::behaviors(), [ 
                &#39;authenticator&#39; => [ 
                    &#39;class&#39; => QueryParamAuth::className() 
                ] 
        ] );
    }
}

最后我們還需要在identityClass中實(shí)現(xiàn)findIdentityByAccessToken方法

public static function findIdentityByAccessToken($token, $type = null)
{
    return static::findOne([&#39;access_token&#39; => $token, &#39;status&#39; => self::STATUS_ACTIVE]);
}

如此一來(lái),我們先通過(guò)postman模擬不帶access-token請(qǐng)求看結(jié)果

{
  "name": "Unauthorized",
  "message": "You are requesting with an invalid credential.",
  "code": 0,
  "status": 401,
  "type": "yii\\web\\UnauthorizedHttpException"
}

提示401 我們沒(méi)有權(quán)限訪問(wèn)!

我們?cè)谡?qǐng)求的鏈接上攜帶正確的access-token,認(rèn)證通過(guò)后,控制器會(huì)再繼續(xù)執(zhí)行其他檢查(頻率限制、操作權(quán)限等),才可以返回正確的用戶(hù)信息。

需要提醒的是:通過(guò)url的形式對(duì)access-token傳遞存在一定的風(fēng)險(xiǎn),有可能會(huì)造成數(shù)據(jù)的泄漏!一般而言,access-token需要放到HTTP頭中進(jìn)行傳遞!除非客戶(hù)端的請(qǐng)求是jsonp格式的!

關(guān)于授權(quán)認(rèn)證,我們有一篇更詳細(xì)的文章,包括一套完整案例、服務(wù)端返回的數(shù)據(jù)類(lèi)型定義、自定義錯(cuò)誤機(jī)制等。

8、速率限制

速率限制,該操作完全也是出于安全考慮,我們需要限制同一接口某時(shí)間段過(guò)多的請(qǐng)求。

速率限制默認(rèn)不啟用,用啟用速率限制,yii\web\User::identityClass 應(yīng)該實(shí)現(xiàn)yii\filters\RateLimitInterface,也就是說(shuō)我們的common\models\User.php需要實(shí)現(xiàn)yii\filters\RateLimitInterface接口的三個(gè)方法,具體代碼可參考:

use yii\filters\RateLimitInterface;
use yii\web\IdentityInterface;
class User extends ActiveRecord implements IdentityInterface, RateLimitInterface
{
    // other code ...... 
    // 返回某一時(shí)間允許請(qǐng)求的最大數(shù)量,比如設(shè)置10秒內(nèi)最多5次請(qǐng)求(小數(shù)量方便我們模擬測(cè)試)
    public  function getRateLimit($request, $action){  
         return [5, 10];  
    }
     
    // 回剩余的允許的請(qǐng)求和相應(yīng)的UNIX時(shí)間戳數(shù) 當(dāng)最后一次速率限制檢查時(shí)
    public  function loadAllowance($request, $action){  
         return [$this->allowance, $this->allowance_updated_at];  
    }  
     
    // 保存允許剩余的請(qǐng)求數(shù)和當(dāng)前的UNIX時(shí)間戳
    public  function saveAllowance($request, $action, $allowance, $timestamp){ 
        $this->allowance = $allowance;  
        $this->allowance_updated_at = $timestamp;  
        $this->save();  
    }  
}

需要注意的是,你仍然需要在數(shù)據(jù)表User中新增加兩個(gè)字段

allowance:剩余的允許的請(qǐng)求數(shù)量

allowance_updated_at:相應(yīng)的UNIX時(shí)間戳數(shù)

在我們啟用了速率限制后,Yii 會(huì)自動(dòng)使用 yii\filters\RateLimiter 為 yii\rest\Controller 配置一個(gè)行為過(guò)濾器來(lái)執(zhí)行速率限制檢查。

現(xiàn)在我們通過(guò)postman請(qǐng)求v1/users再看看結(jié)果,會(huì)發(fā)現(xiàn)在10秒內(nèi)調(diào)用超過(guò)5次API接口,我們會(huì)得到狀態(tài)為429太多請(qǐng)求的異常信息。

{
  "name": "Too Many Requests",
  "message": "Rate limit exceeded.",
  "code": 0,
  "status": 429,
  "type": "yii\\web\\TooManyRequestsHttpException"
}

9、關(guān)于版本

為了兼容歷史版本而且考慮向后兼容性,我們?cè)谝婚_(kāi)始操作的時(shí)候就以URL的方式實(shí)現(xiàn)了版本話,這里就不再進(jìn)行闡述了。

10、錯(cuò)誤處理

Yii的REST框架的HTTP狀態(tài)代碼可參考如下就好,沒(méi)啥好說(shuō)的

200: OK。一切正常。

201: 響應(yīng) POST 請(qǐng)求時(shí)成功創(chuàng)建一個(gè)資源。Location header 包含的URL指向新創(chuàng)建的資源。

204: 該請(qǐng)求被成功處理,響應(yīng)不包含正文內(nèi)容 (類(lèi)似 DELETE 請(qǐng)求)。

304: 資源沒(méi)有被修改??梢允褂镁彺娴陌姹?。

400: 錯(cuò)誤的請(qǐng)求。可能通過(guò)用戶(hù)方面的多種原因引起的,例如在請(qǐng)求體內(nèi)有無(wú)效的JSON 數(shù)據(jù),無(wú)效的操作參數(shù),等等。

401: 驗(yàn)證失敗。

403: 已經(jīng)經(jīng)過(guò)身份驗(yàn)證的用戶(hù)不允許訪問(wèn)指定的 API 末端。

404: 所請(qǐng)求的資源不存在。

405: 不被允許的方法。 請(qǐng)檢查 Allow header 允許的HTTP方法。

415: 不支持的媒體類(lèi)型。 所請(qǐng)求的內(nèi)容類(lèi)型或版本號(hào)是無(wú)效的。

422: 數(shù)據(jù)驗(yàn)證失敗 (例如,響應(yīng)一個(gè) POST 請(qǐng)求)。 請(qǐng)檢查響應(yīng)體內(nèi)詳細(xì)的錯(cuò)誤消息。

429: 請(qǐng)求過(guò)多。 由于限速請(qǐng)求被拒絕。

500: 內(nèi)部服務(wù)器錯(cuò)誤。 這可能是由于內(nèi)部程序錯(cuò)誤引起的。

以上がyii2 で API インターフェースを作成する手順の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見(jiàn)つけた場(chǎng)合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫(huà)像を無(wú)料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫(xiě)真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫(xiě)真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類(lèi)リムーバー

Video Face Swap

Video Face Swap

完全無(wú)料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡(jiǎn)単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無(wú)料のコードエディター

SublimeText3 中國(guó)語(yǔ)版

SublimeText3 中國(guó)語(yǔ)版

中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開(kāi)発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開(kāi)発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Yii Assetバンドルとは何ですか?また、それらの目的は何ですか? Yii Assetバンドルとは何ですか?また、それらの目的は何ですか? Jul 07, 2025 am 12:06 AM

yiiiasetbundlesorizeandmanagewebassetslikecss、javascript、andimagesinayiiapplication.1

コントローラーからビューをレンダリングするにはどうすればよいですか? コントローラーからビューをレンダリングするにはどうすればよいですか? Jul 07, 2025 am 12:09 AM

コントローラーがMVCフレームワークでビューをレンダリングするメカニズムは、命名規(guī)則に基づいており、明示的な上書(shū)きを可能にします。リダイレクトが明示的に示されていない場(chǎng)合、コントローラーは、レンダリングのアクションと同じ名前のビューファイルを自動(dòng)的に見(jiàn)つけます。 1.ビューファイルが存在し、正しく名前が付けられていることを確認(rèn)してください。たとえば、コントローラーPostscontrollerのアクションショーに対応するビューパスは、ビュー/投稿/show.html.erbまたはviews/posts/show.cshtmlである必要があります。 2。lavels and View( 'posts.custom_template')のrender'custom_template 'など、lander'custom_template'などのさまざまなテンプレートを指定するには、明示的なレンダリングを使用してください。

YIIモデルを使用してデータをデータベースに保存するにはどうすればよいですか? YIIモデルを使用してデータをデータベースに保存するにはどうすればよいですか? Jul 05, 2025 am 12:36 AM

YIIフレームワークのデータベースにデータを保存すると、主にActiverCordモデルを通じて実裝されます。 1.新しいレコードを作成するには、モデルのインスタンス化、データの読み込み、保存前に検証する必要があります。 2。レコードを更新するには、割り當(dāng)て前に既存のデータを照會(huì)する必要があります。 3.バッチ割り當(dāng)てにload()メソッドを使用する場(chǎng)合、セキュリティ屬性はルール()でマークする必要があります。 4.関連データを保存する場(chǎng)合、一貫性を確保するためにトランザクションを使用する必要があります。特定の手順には、次のものが含まれます。モデルをインスタンス化し、データをload()で埋めること、validate()検証を呼び出し、最後にsave()永続性を?qū)g行します。更新するときは、最初にレコードを取得し、次に値を割り當(dāng)てます。敏感なフィールドが関與している場(chǎng)合、大量署名を制限する必要があります。関連するモデルを保存するときは、BeginTranを組み合わせる必要があります

Yiiで基本的なルートを作成するにはどうすればよいですか? Yiiで基本的なルートを作成するにはどうすればよいですか? Jul 09, 2025 am 01:15 AM

to cleateabasicrouteinyii、firstsetupacontrollerbyplacingintinthecontrollersdirectory withdirectory andclassdextendinitionextendingingyii \ controller.1)createanactionwithincontrollollerbydefingmethodstartingwith ".2)“ .2)" .2)

YIIコントローラーでカスタムアクションを作成するにはどうすればよいですか? YIIコントローラーでカスタムアクションを作成するにはどうすればよいですか? Jul 12, 2025 am 12:35 AM

YIIでカスタム操作を作成する方法は、コントローラー內(nèi)のアクションから始まる一般的な方法を定義し、オプションでパラメーターを受け入れることです。次に、データを処理したり、ビューをレンダリングしたり、必要に応じてJSONを返します。最後に、アクセス制御を通じてセキュリティを確保します。特定の手順には以下が含まれます。1。アクションが付いたメソッドを作成します。 2.メソッドを公開(kāi)に設(shè)定します。 3。URLパラメーターを受信できます。 4.モデルのクエリ、POSTリクエストの処理、リダイレクトなどのプロセスデータ。 5.アクセス制御を使用するか、アクセス権を手動(dòng)でチェックしてアクセスを制限します。たとえば、ActionProfile($ ID)には /site /profile?id = 123からアクセスでき、ユーザープロファイルページをレンダリングできます。ベストプラクティスはです

YII開(kāi)発者:必要な役割、責(zé)任、およびスキル YII開(kāi)発者:必要な役割、責(zé)任、およびスキル Jul 12, 2025 am 12:11 AM

ayiideveloper crafterswebapplicationsusingheyiiframework、requiredskillsinphp、yii-specificknowledge、andwebdevelopmentlifecyclemanagement.keyresponsibilitivitiationinclude:1)writingeficientcodetooptimizeperformance、2)diritisising suritizationsecuritytoprotectectecteptrications

YiiでActiverCordパターンを使用するにはどうすればよいですか? YiiでActiverCordパターンを使用するにはどうすればよいですか? Jul 09, 2025 am 01:08 AM

toucteverecordinyieiefectivilly、you createamodelclass foreachtable databaseusingobject-orientedmethods.first、definemodelclassextendendingyii \ db \ activerecordand specificificificificificificificificificificificifytififytirestrendingturningturningturningternameviatemadelame()

YII開(kāi)発者の職務(wù)記述書(shū):主要な責(zé)任と資格 YII開(kāi)発者の職務(wù)記述書(shū):主要な責(zé)任と資格 Jul 11, 2025 am 12:13 AM

ayiideveloper'skeyresponsibilitivitioninginginginginginginginginginginging、Andoptimizingperformance. qualifications neededareastronggraspofphp、エクスペリエンスエンドテクノロジー、Databasemanagementskills、およびproblem-solvisabi

See all articles