我在PHP yii2中得到数组(0)?

时间:2016-12-28 18:23:56

标签: php jquery json yii2 yii2-advanced-app

我将array(0)作为var_dump。

tbl_supplierOrderDetails['user_id']array(2) {
  ["tbl_supplierOrderDetails"]=>
  array(0) {
  }
  ["tbl_userContactDetails"]=>
  array(0) {
  }
}

这是我使用php yii2

的API示例
 public function actionSuggestions()
    {   
        $listingId = Yii::$app->request->get('listing_id');
        $apiUrl = "http://example.com:8800/api/Home/view_supplierOrderDetails?listing_id=".$listingId;
        $suggestions = file_get_contents($apiUrl);
        $suggestions = json_decode($suggestions, JSON_PRETTY_PRINT);
        echo "tbl_supplierOrderDetails['user_id']";
        //print_r($suggestions);
        var_dump($suggestions);
         exit;
        return $this->render('suggestions' , array(
            'listingId' => $listingId,
            'suggestions' => $suggestions,
        ));
    }

这是我的json格式的api演示。

 {
      "tbl_supplierOrderDetails": [
        {
          "num": 1,
          "user_id": 3496,
          "priority": "A.closed",
          "no_of_times": 5,
          "username": "eyuw",
          "company_name": "djff",
          "email": "abc@gmail.com",
          "contact_no": "9999999999",
          "origin": "abc",
          "dest": "xyz",
          "vehicle_class": "abc,
          "vehicle_type": "abc",
          "notes": "TCS_"
        }]
    "tbl_userContactDetails": [
        {
          "user_id": 500,
          "contact_name": "Mr abc",
          "contact_email": "abc@gmail.com",
          "contact_mobile": 9999999999,
          "contact_mobile2": null
        }]
    }

我想在html的不同部分显示这些细节。我怎么能通过这个api来做到这一点。

1 个答案:

答案 0 :(得分:0)

首先,确保变量$ suggestions包含您期望的数据。

您的结构是完全错误的,因此,我想向您推荐一个好的结构。

public function actionSuggestions() {
    try {
        $message = array();
        $listingId = Yii::$app->request->get('listing_id');
        if (!empty($listingId)) {
            $apiUrl = "http://example.com:8800/api/Home/view_supplierOrderDetails?listing_id=" . $listingId;
            $suggestions = file_get_contents($apiUrl);
            $suggestions = json_decode($suggestions, JSON_PRETTY_PRINT);

            //if $suggestions contains required data then you can return those data
            $message = ['status' => 'success', 'message' => 'Data fetched succesfully', 'data' => $suggestions];

            //else build an array like what format you want
        } else {
            $message = ['status' => 'failed', 'message' => 'Missing parameters.'];
        }
    } catch (\Exception $exception) {
        $message = ['status' => 'failed', 'message' => "Some exception occured."];
    }
    return $message;
}

在这里您可以期待json输出,如下所示:

{
"status" : "success",
"message" : "Data fetched succesfully",
"data" : {

    }
 }