簡體   English   中英

yii2中使用GET方法但不使用POST方法的API工作

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM