国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁(yè) php框架 YII yii2寫(xiě)api介面步驟

yii2寫(xiě)api介面步驟

Nov 06, 2019 pm 05:32 PM
yii2

yii2寫(xiě)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寫(xiě)api介面步驟

yii2寫(xiě)api介面步驟

yii2寫(xiě)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)建了滿足restful風(fēng)格的api了。為了更好更方便的演示,我們借助工具postman進(jìn)行模擬請(qǐng)求。

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

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

yii2寫(xiě)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è)列出所有用戶
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)詞

不信的話我們可以利用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ō)用戶要設(shè)置自己的信息。

為了對(duì)yii2 restful授權(quán)認(rèn)證說(shuō)的更清楚,我們將會(huì)以兩個(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)限等),才可以返回正確的用戶信息。

需要提醒的是:通過(guò)url的形式對(duì)access-token傳遞存在一定的風(fēng)險(xiǎn),有可能會(huì)造成數(shù)據(jù)的泄漏!一般而言,access-token需要放到HTTP頭中進(jìn)行傳遞!除非客戶端的請(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ò)用戶方面的多種原因引起的,例如在請(qǐng)求體內(nèi)有無(wú)效的JSON 數(shù)據(jù),無(wú)效的操作參數(shù),等等。

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

403: 已經(jīng)經(jīng)過(guò)身份驗(yàn)證的用戶不允許訪問(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寫(xiě)api介面步驟的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門(mén)話題

如何配置YII小部件? 如何配置YII小部件? Jun 18, 2025 am 12:01 AM

toConfigureAiiiwidget,YouCallitWithAconFigurationArrayThatSetsPropertiesAndOptions.1.usethesyntax \\ yii \\ widgets \\ className :: w IDGET($ config)

如何在操作系統(tǒng)(Windows,MacOS,Linux)上安裝YII? 如何在操作系統(tǒng)(Windows,MacOS,Linux)上安裝YII? Jun 17, 2025 am 09:21 AM

安裝Yii框架需根據(jù)不同操作系統(tǒng)配置PHP和Composer,具體步驟如下:1.Windows上需手動(dòng)下載PHP並配置環(huán)境變量,再安裝Composer,使用命令創(chuàng)建項(xiàng)目並運(yùn)行內(nèi)置服務(wù)器;2.macOS推薦用Homebrew安裝PHP和Composer,接著創(chuàng)建項(xiàng)目並啟動(dòng)開(kāi)發(fā)服務(wù)器;3.Linux(如Ubuntu)通過(guò)apt安裝PHP及擴(kuò)展和Composer,然後創(chuàng)建項(xiàng)目並配合Apache或Nginx部署正式環(huán)境。不同系統(tǒng)的主要差異在環(huán)境搭建階段,一旦PHP和Composer就緒,後續(xù)流程一致,注

如何以形式顯示驗(yàn)證錯(cuò)誤? 如何以形式顯示驗(yàn)證錯(cuò)誤? Jun 19, 2025 am 12:02 AM

當(dāng)用戶提交表單信息有誤或缺失時(shí),清晰展示驗(yàn)證錯(cuò)誤至關(guān)重要。 1.使用內(nèi)聯(lián)錯(cuò)誤消息,在相關(guān)字段旁邊直接顯示具體錯(cuò)誤,如“請(qǐng)輸入有效的電子郵件地址”,而非籠統(tǒng)提示;2.通過(guò)紅色邊框、背景色或警告圖標(biāo)等視覺(jué)方式標(biāo)記問(wèn)題字段,增強(qiáng)可讀性;3.在表單較長(zhǎng)或結(jié)構(gòu)複雜時(shí),在頂部顯示可點(diǎn)擊跳轉(zhuǎn)的錯(cuò)誤摘要,但需與內(nèi)聯(lián)消息配合使用;4.在合適的情況下啟用實(shí)時(shí)驗(yàn)證,在用戶輸入或離開(kāi)字段時(shí)即時(shí)反饋,例如檢查郵箱格式或密碼強(qiáng)度,但避免在用戶未提交前過(guò)早提示。這些方法能有效引導(dǎo)用戶快速修正輸入錯(cuò)誤,提升表單填寫(xiě)體驗(yàn)。

最高技能每個(gè)YII框架開(kāi)發(fā)人員都需要 最高技能每個(gè)YII框架開(kāi)發(fā)人員都需要 Jun 20, 2025 am 12:03 AM

成為Yii框架開(kāi)發(fā)者的關(guān)鍵技能包括:1)精通PHP和麵向?qū)ο缶幊蹋∣OP),2)理解MVC架構(gòu),3)熟練使用Yii的ActiveRecord,4)熟悉Yii的Gii工具,5)掌握RESTfulAPI開(kāi)發(fā),6)具備前端整合技能,7)掌握調(diào)試和性能優(yōu)化,8)持續(xù)學(xué)習(xí)和社區(qū)參與。這些技能結(jié)合起來(lái),能夠幫助開(kāi)發(fā)者在Yii框架中高效工作。

如何在yii中創(chuàng)建表格? 如何在yii中創(chuàng)建表格? Jun 23, 2025 am 12:03 AM

在Yii框架中創(chuàng)建表單的核心流程包括四個(gè)步驟:1.創(chuàng)建模型類(lèi),定義字段和驗(yàn)證規(guī)則;2.在控制器中處理表單提交與驗(yàn)證邏輯;3.使用ActiveForm在視圖中渲染表單元素;4.注意CSRF防護(hù)、佈局與樣式配置。模型類(lèi)通過(guò)rules()方法設(shè)定必填項(xiàng)和數(shù)據(jù)格式,控制器使用load()和validate()處理提交數(shù)據(jù),視圖借助ActiveForm自動(dòng)生成帶標(biāo)籤和錯(cuò)誤提示的輸入框,並可自定義佈局和樣式,從而實(shí)現(xiàn)功能完整的表單系統(tǒng)。

Yii vs. Laravel:為您的項(xiàng)目選擇正確的PHP框架 Yii vs. Laravel:為您的項(xiàng)目選擇正確的PHP框架 Jul 02, 2025 am 12:26 AM

選擇Yii還是Laravel取決於項(xiàng)目需求和團(tuán)隊(duì)專(zhuān)長(zhǎng)。 1)Yii適合高性能需求,結(jié)構(gòu)輕量。 2)Laravel提供豐富功能,開(kāi)發(fā)者友好,適合複雜應(yīng)用。兩者均可擴(kuò)展,但Yii更易於模塊化,而Laravel社區(qū)資源更豐富。

如何在控制器中使用buforeaction()和afteraction()方法? 如何在控制器中使用buforeaction()和afteraction()方法? Jul 02, 2025 am 12:03 AM

beforeAction()在Yii2中用於在控制器動(dòng)作執(zhí)行前運(yùn)行邏輯,如權(quán)限檢查或請(qǐng)求修改,必須返回true或父類(lèi)調(diào)用以繼續(xù)執(zhí)行;afterAction()則在動(dòng)作執(zhí)行後、響應(yīng)發(fā)送前運(yùn)行,適用於輸出修改或日誌記錄。 1.beforeAction()在動(dòng)作執(zhí)行前運(yùn)行,可用於用戶權(quán)限驗(yàn)證,例如重定向未登錄用戶至登錄頁(yè),需返回parent::beforeAction($action)或true以繼續(xù)流程,否則阻止動(dòng)作執(zhí)行;2.可通過(guò)檢查$action->id跳過(guò)特定動(dòng)作的檢查;3.afterAc

YII開(kāi)發(fā)人員是否有未來(lái)的工作? YII開(kāi)發(fā)人員是否有未來(lái)的工作? Jun 22, 2025 am 12:09 AM

Yii開(kāi)發(fā)者的職業(yè)前景仍然存在,但需要多樣化技能。 1)Yii在企業(yè)應(yīng)用中仍有需求,但市場(chǎng)競(jìng)爭(zhēng)激烈。 2)Yii技能可轉(zhuǎn)移到其他PHP框架。 3)Yii社區(qū)支持較小,但資源充足。 4)通過(guò)學(xué)習(xí)其他框架和保持Yii更新來(lái)提升職業(yè)靈活性。

See all articles