Как я должен декодировать правильный ответ JSON? - PullRequest
0 голосов
/ 27 июня 2019

Я использую Laravel 5.7 для создания API, который обеспечивает ответ JSON. Я создаю следующий JSON, но он требует некоторых изменений. Таблица содержит столбцы booking_pics, в которых несколько изображений хранятся с использованием, разделенных. Я хочу получить в JSON как объект в массиве. Я показываю JSON, но отображается только последнее изображение, другие нет, нужно решение.

Контроллер:

$get_booking_details= DB::table('table_booking_list')
            ->join('table_booking_details', 'table_booking_list.booking_id', '=', 'table_booking_details.booking_id')
            ->select('table_booking_details.*')
            ->where('table_booking_details.booking_id',$booking_id)
            ->get();

            foreach($get_booking_details as $item)
            {
                foreach(explode(",",$item->booking_pics) as $items)
                {
                   $item->booking_pics=[["image" => $items]];
                }
            }
            return response()->json(['success' => '1','data' =>$get_booking_details]);

json response:

{
    "success": "1",
    "data": [
        {
            "id": 1,
            "booking_list_id": 1,
            "booking_id": 1,
            "booking_name": "hockey stadium",
            "booking_area": "kolhapur",
            "booking_status": 0,
            "time": "6.00 am to 8.00pm",
            "booking_pics": [
                {
                    "image": "http://192.168.1.132:8000/images/ground_pic/2.jpg"
                }
            ],
            "available_sports": "hockey,cricket",
            "booking_amenities": "parking,toilet,water",
            "booking_rating": 4.5,
            "booking_area_address": "MSEB Ring Road, Datta Colony, Kolhapur, Maharashtra, 416008",
            "longitude": "85.501980",
            "latitude": "23.624420",
            "updated_at": "2019-06-26 16:42:02",
            "created_at": "0000-00-00 00:00:00"
        }
    ]
}

Требуется JSON:

{
    "success": "1",
    "data": [{
        "id": 1,
        "booking_list_id": 1,
        "booking_id": 1,
        "booking_name": "hockey stadium",
        "booking_area": "kolhapur",
        "booking_status": 0,
        "time": "6.00 am to 8.00pm",
        "booking_pics": [{
                "image": "http://192.168.1.132:8000/images/ground_pic/1.jpg"
            },
            {
                "image": "http://192.168.1.132:8000/images/ground_pic/2.jpg"
            }
        ],
        "available_sports": "hockey,cricket",
        "booking_amenities": "parking,toilet,water",
        "booking_rating": 4.5,
        "booking_area_address": "MSEB Ring Road, Datta Colony, Kolhapur, Maharashtra, 416008",
        "longitude": "85.501980",
        "latitude": "23.624420",
        "updated_at": "2019-06-26 16:42:02",
        "created_at": "0000-00-00 00:00:00"
    }]
}

Ответы [ 2 ]

0 голосов
/ 27 июня 2019

самым быстрым способом было бы создание модели и приведение данных из базы данных в виде json

в модели

protected $casts = [
    'booking_pics' => 'json',
];
0 голосов
/ 27 июня 2019

Сделай так

        foreach($get_booking_details as $item)
        {
            foreach(explode(",",$item->booking_pics) as $items)
            {
               $item->booking_pics["image"][] = $items;
            }
        }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...