目录
api\controllers\OnAuthController,注意Curd是改过的,不想用系统的Curd可直接继承 api\controllers\ActiveController,如果设置控制器内方法不需要验证请设置 optional 属性api\controllers\UserAuthController可自行修改
common\models\common\RateLimit配置
找到 common\models\api\AccessToken 让其直接继承 common\models\base\BaseModel 即可
只需要在返回之前加上这行代码就可以不进行格式化返回
Yii::$app->params['triggerBeforeSend'] = true
可自行修改
api/config/params.php配置
测试控制器:api\controllers\SignSecretKeyController,注意要先开启路由规则匹配才能访问
return [
// 签名验证默认不关闭验证,如果开启需了解签名生成及验证
'user.httpSignValidity' => false,
// 签名授权公钥秘钥
'user.httpSignAccount' => [
'doormen' => 'e3de3825cfbf',
],
];
在执行访问方法前系统会先调用
checkAccess方法来检测该方法能不能被验证通过,可以在控制器内添加该方法来判断权限,如果不需要可忽略。下面是个例子,不想让外部访问 delete 和 index 方法
/**
* 权限验证
*
* @param string $action 当前的方法
* @param null $model 当前的模型类
* @param array $params $_GET变量
* @throws \yii\web\BadRequestHttpException
*/
public function checkAccess($action, $model = null, $params = [])
{
// 方法名称
if (in_array($action, ['delete', 'index'])) {
throw new \yii\web\BadRequestHttpException('权限不足');
}
}
请自行修改
api\behaviors\BeforeSend行为
注意: 有些前端没有接触过状态码在Http头里面返回所以可以 在 BeforeSend 数据处理后开启$response->statusCode = 200;
/**
* 返回json数据格式
*
* 注意:要符合http状态码 否则报错
*
* @param int $code 状态码
* @param string $message 返回的报错信息
* @param array|object $data 返回的数据结构
*/
common\helpers\ResultHelper::json($code, $message, $data = []);
/**
* 注意这里传递的变量一定是 `$model->getFirstErrors()` 的数据
*
* @param $fistErrors
* @return string
*/
$this->analysisErr($model->getFirstErrors())
use common\models\member\Member;
$tokenModel = Yii::$app->user->identity;
$member = Yii::$app->services->member->get($tokenModel['member_id']);