?
本文檔使用 PHP中文網(wǎng)手冊(cè) 發(fā)布
在創(chuàng)建資源類和指定資源格輸出式化后,下一步就是創(chuàng)建控制器操作將資源通過(guò)RESTful APIs展現(xiàn)給終端用戶。
Yii 提供兩個(gè)控制器基類來(lái)簡(jiǎn)化創(chuàng)建RESTful 操作的工作:yii\rest\Controller 和 yii\rest\ActiveController, 兩個(gè)類的差別是后者提供一系列將資源處理成Active Record的操作。 因此如果使用Active Record內(nèi)置的操作會(huì)比較方便,可考慮將控制器類 繼承yii\rest\ActiveController,它會(huì)讓你用最少的代碼完成強(qiáng)大的RESTful APIs.
yii\rest\Controller 和 yii\rest\ActiveController 提供以下功能,一些功能在后續(xù)章節(jié)詳細(xì)描述:
yii\rest\ActiveController 額外提供一下功能:
index
,?view
,?create
,?update
,?delete
,?options
;當(dāng)創(chuàng)建一個(gè)新的控制器類,控制器類的命名最好使用資源名稱的單數(shù)格式,例如,提供用戶信息的控制器 可命名為UserController
.
創(chuàng)建新的操作和Web應(yīng)用中創(chuàng)建操作類似,唯一的差別是Web應(yīng)用中調(diào)用render()
方法渲染一個(gè)視圖作為返回值, 對(duì)于RESTful操作直接返回?cái)?shù)據(jù),yii\rest\Controller::serializer 和 yii\web\Response 會(huì)處理原始數(shù)據(jù)到請(qǐng)求格式的轉(zhuǎn)換,例如
public function actionView($id){
return User::findOne($id);
}
yii\rest\Controller提供的大多數(shù)RESTful API功能通過(guò)過(guò)濾器實(shí)現(xiàn). 特別是以下過(guò)濾器會(huì)按順序執(zhí)行:
這些過(guò)濾器都在yii\rest\Controller::behaviors()方法中聲明, 可覆蓋該方法來(lái)配置單獨(dú)的過(guò)濾器,禁用某個(gè)或增加你自定義的過(guò)濾器。 例如,如果你只想用HTTP 基礎(chǔ)認(rèn)證,可編寫如下代碼:
use yii\filters\auth\HttpBasicAuth;
public function behaviors(){
$behaviors = parent::behaviors();
$behaviors['authenticator'] = [
'class' => HttpBasicAuth::className(),
];
return $behaviors;
}
ActiveController
如果你的控制器繼承yii\rest\ActiveController,應(yīng)設(shè)置yii\rest\ActiveController::modelClass 屬性 為通過(guò)該控制器返回給用戶的資源類名,該類必須繼承yii\db\ActiveRecord.
yii\rest\ActiveController 默認(rèn)提供一下操作:
所有這些操作通過(guò)yii\rest\ActiveController::actions() 方法申明,可覆蓋actions()
方法配置或禁用這些操作, 如下所示:
public function actions(){
$actions = parent::actions();
// 禁用"delete" 和 "create" 操作
unset($actions['delete'], $actions['create']);
// 使用"prepareDataProvider()"方法自定義數(shù)據(jù)provider
$actions['index']['prepareDataProvider'] = [$this, 'prepareDataProvider'];
return $actions;
}
public function prepareDataProvider(){
// 為"index"操作準(zhǔn)備和返回?cái)?shù)據(jù)provider
}
請(qǐng)參考獨(dú)立操作類的參考文檔學(xué)習(xí)哪些配置項(xiàng)有用。
通過(guò)RESTful APIs顯示數(shù)據(jù)時(shí),經(jīng)常需要檢查當(dāng)前用戶是否有權(quán)限訪問(wèn)和操作所請(qǐng)求的資源, 在yii\rest\ActiveController中,可覆蓋yii\rest\ActiveController::checkAccess()方法來(lái)完成權(quán)限檢查。
public function checkAccess($action, $model = null, $params = []){
// 檢查用戶能否訪問(wèn) $action 和 $model
// 訪問(wèn)被拒絕應(yīng)拋出ForbiddenHttpException
}
checkAccess()
?方法默認(rèn)會(huì)被yii\rest\ActiveController默認(rèn)操作所調(diào)用,如果創(chuàng)建新的操作并想執(zhí)行權(quán)限檢查, 應(yīng)在新的操作中明確調(diào)用該方法。
checkAccess()
。