[英]API Work using GET method but not using POST method in yii2
在這里,我使用POST方法編寫用於注冊時間表的API,用於使用郵遞員檢查API,但是如果我使用GET方法來安裝POST,則它不適用於POST方法嗎?
public function actionRegister() {
$response = [];
if (isset($_POST['practiceCode']) &&
isset($_POST['officeID']) &&
isset($_POST['token']) &&
isset($_POST['workingDays']) &&
isset($_POST['morningStart']) &&
isset($_POST['morningEnd']) &&
isset($_POST['afternoonStart']) &&
isset($_POST['afternoonEnd']) &&
isset($_POST['eveningStart']) &&
isset($_POST['eveningEnd'])) {
$practiceModel = Practice::find()->where(['practiceCode' => $_POST['practiceCode'], 'deleted' => 'N'])->one();
if ($practiceModel != null) {
$officeModel = Office::find()->where(['practiceCode' => $_POST['practiceCode'], 'deleted' => 'N'])->all();
if ($officeModel != null) {
$arrayOffice = Office::find()->where(['id' => $_POST['officeID'], 'deleted' => 'N'])->one();
if($arrayOffice != null) {
$scheduleModel = new Schedule();
$scheduleModel->officeID = $_POST['officeID'];
$scheduleModel->token = $_POST['token'];
$scheduleModel->workingDays = $_POST['workingDays'];
$scheduleModel->morningStart = $_POST['morningStart'];
$scheduleModel->morningEnd = $_POST['morningEnd'];
$scheduleModel->afternoonStart = $_POST['afternoonEnd'];
$scheduleModel->eveningStart = $_POST['eveningStart'];
$scheduleModel->eveningEnd = $_POST['eveningEnd'];
// $scheduleModel->practiceCode = $_POST['practiceCode'];
if ($scheduleModel->save()) {
$response = ['code' => '200',
'result' => 'Success',
'message' => 'Schedule created successfully',
'details' => $scheduleModel->toArray(),
];
} else {
$response = ['code' => '400',
'result' => 'Failure',
'message' => 'Could not Schedule you at this moment'];
}
} else {
$response = ['code' => '400',
'result' => 'Failure',
'message' => 'Specified Office does not exist.',
];
}
} else {
$response = ['code' => '400',
'result' => 'Failure',
'message' => 'Specified practice code Office does not exist.',
];
}
} else {
$response = ['code' => '400',
'result' => 'Failure',
'message' => 'Specified practice code does not exist. ',
];
}
} else {
$response = ['code' => '400',
'result' => 'Failure',
'message' => 'Invalid request/missing parameters',
];
}
\Yii::$app->response->format = 'json';
return $response;
}
為了安全起見,yii 2.0不允許第三方POST請求。 例如,以您的郵遞員為例。 要啟用您的POST請求,請將其添加到您的控制器中:
this->$enableCsrfValidation = false;
您可以檢查stackoverflow網站,有很多與此相關的主題。
對Yii2中的單個操作禁用CSRF驗證
如需進一步閱讀,請查看:
Yii 2.0參考
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.