Opencart 2 admin api在维护模式下调用

时间:2015-02-22 10:52:47

标签: php opencart opencart2.x

当我将我的网站置于维护模式并尝试使用管理员的订单历史记录时,我得到:

  

SyntaxError:JSON.parse:第1行第1列的意外数据结尾   JSON数据

如何在curl请求中传递身份验证数据,以便以管理员身份登录时禁用维护模式?

public function api() {
    $json = array();

    // Store
    if (isset($this->request->get['store_id'])) {
        $store_id = $this->request->get['store_id'];
    } else {
        $store_id = 0;
    }

    $this->load->model('setting/store');

    $store_info = $this->model_setting_store->getStore($store_id);

    if ($store_info) {
        $url = $store_info['ssl'];
    } else {
        $url = HTTPS_CATALOG;
    }

    if (isset($this->session->data['cookie']) && isset($this->request->get['api'])) {
        // Include any URL perameters
        $url_data = array();

        foreach ($this->request->get as $key => $value) {
            if ($key != 'route' && $key != 'token' && $key != 'store_id') {
                $url_data[$key] = $value;
            }
        }

        $curl = curl_init();

        // Set SSL if required
        if (substr($url, 0, 5) == 'https') {
            curl_setopt($curl, CURLOPT_PORT, 443);
        }

        curl_setopt($curl, CURLOPT_HEADER, false);
        curl_setopt($curl, CURLINFO_HEADER_OUT, true);
        curl_setopt($curl, CURLOPT_USERAGENT, $this->request->server['HTTP_USER_AGENT']);
        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
        curl_setopt($curl, CURLOPT_FORBID_REUSE, false);
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($curl, CURLOPT_URL, $url . 'index.php?route=' . $this->request->get['api'] . ($url_data ? '&' . http_build_query($url_data) : ''));

        if ($this->request->post) {
            curl_setopt($curl, CURLOPT_POST, true);
            curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($this->request->post));
        }

        curl_setopt($curl, CURLOPT_COOKIE, session_name() . '=' . $this->session->data['cookie'] . ';');

        $json = curl_exec($curl);

        curl_close($curl);
    }

    $this->response->addHeader('Content-Type: application/json');
    $this->response->setOutput($json);
}

我注意到在其他方法中,他们是api / login的额外请求。有没有办法可以将2合并在一起

$api_info = $this->model_user_api->getApi($this->config->get('config_api_id'));

if ($api_info) {
    $curl = curl_init();

    // Set SSL if required
    if (substr(HTTPS_CATALOG, 0, 5) == 'https') {
        curl_setopt($curl, CURLOPT_PORT, 443);
    }

    curl_setopt($curl, CURLOPT_HEADER, false);
    curl_setopt($curl, CURLINFO_HEADER_OUT, true);
    curl_setopt($curl, CURLOPT_USERAGENT, $this->request->server['HTTP_USER_AGENT']);
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($curl, CURLOPT_FORBID_REUSE, false);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($curl, CURLOPT_URL, HTTPS_CATALOG . 'index.php?route=api/login');
    curl_setopt($curl, CURLOPT_POST, true);
    curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($api_info));

    $json = curl_exec($curl);

    if (!$json) {
        $this->error['warning'] = sprintf($this->language->get('error_curl'), curl_error($curl), curl_errno($curl));
    } else {
        $response = json_decode($json, true);

        if (isset($response['cookie'])) {
            $this->session->data['cookie'] = $response['cookie'];
        }

        curl_close($curl);
    }
}

1 个答案:

答案 0 :(得分:1)

在OpenCart的github问题列表中已经多次注意到了这一点。这还没有修复,但是this commit显示了你需要做些什么来实现这个目标