проблема с возвратом некоторых списков в Json: ASP.NET Core - PullRequest
0 голосов
/ 09 сентября 2018

Я создаю API, который возвращает некоторые результаты из базы данных MySql. У меня есть таблица, включающая 2 строки и несколько полей. Основным фактором для запроса является поле с именем Title. Приложение должно возвращать результаты на основе поля «title». titles из этих двух записей: Сладкая улица и Сладкая улица 2 .

для возврата результатов в формате JSON я создал класс:

using System.Collections.Generic;
namespace IMES_Backend.Controllers
{
    internal class Movie
    {
        public class BaseResponse
        {
            public List<Item> search { get; set; } = new List<Item>();
            public bool response { get; set; }

        }

        public class Item
        {
            public string title { get; set; }
            public string year { get; set; }
            public string released { get; set; }
            public string runTime { get; set; }
            public string genre { get; set; }
            public string director { get; set; }
            public string writer { get; set; }
            public string actors { get; set; }
            public string language { get; set; }
            public string country { get; set; }
            public string awards { get; set; }
            public string poster { get; set; }
            public string imdbScore { get; set; }
            public string production { get; set; }
            public string dl480p { get; set; }
            public string dl720p { get; set; }
            public string dl1080p { get; set; }
            public string subtitleLink { get; set; }
            public string dubLink { get; set; }
            public string description { get; set; }
            public string state { get; set; }

        }
    }
}

Затем я выбираю эти 2 строки, как упоминалось ранее, и возвращаю результаты в формате JSON:

    [Route("IMES/api/GET/search/t={movieTitle}")]
    [HttpGet]
    public IActionResult MovieSearch(string movieTitle)
    {
        string searchKeyword = movieTitle.Replace("%20", " ");

        //Try to connect to the database
        try
        {
            DB.dbConnection.Open();
            MySqlCommand cmd = new MySqlCommand("select * from Movies where Title LIKE '%" + searchKeyword + "%'",DB.dbConnection);
            DB.dataReader = cmd.ExecuteReader();

            while (DB.dataReader.Read())
            {
                baseResponse.response = true;

                //Create a list for storing the movie's data
                baseResponse.search.Add(new Movie.Item
                {
                    title = DB.dataReader.GetString(1),
                    year = DB.dataReader.GetString(2),
                    released = DB.dataReader.GetString(3),
                    runTime = DB.dataReader.GetString(4),
                    genre = DB.dataReader.GetString(5),
                    director = DB.dataReader.GetString(6),
                    writer = DB.dataReader.GetString(7),
                    actors = DB.dataReader.GetString(8),
                    language = DB.dataReader.GetString(9),
                    country = DB.dataReader.GetString(10),
                    awards = DB.dataReader.GetString(11),
                    poster = DB.dataReader.GetString(12),
                    imdbScore = DB.dataReader.GetString(13),
                    production = DB.dataReader.GetString(14),
                    dl480p = DB.dataReader.GetString(15),
                    dl720p = DB.dataReader.GetString(16),
                    dl1080p = DB.dataReader.GetString(17),
                    subtitleLink = DB.dataReader.GetString(18),
                    dubLink = DB.dataReader.GetString(19),
                    description = DB.dataReader.GetString(20),
                    state = DB.dataReader.GetString(21),
                });

                string response = JsonConvert.SerializeObject(baseResponse);
                return Ok(response);

            }
        }
        catch(MySqlException ex) //MySql connection problem
        {
            return Ok(ex.Message);
        }
        finally
        {
            DB.dbConnection.Close();
            DB.dataReader.Close();
        }
        baseResponse.response = false;
        string error = JsonConvert.SerializeObject(baseResponse.response);
        return Ok(error);
    }

Когда я просматриваю .../IMES/api/GET/search/t=sweet, я просто получаю данные первых строк, для второй строки нет второго списка, включающего ключевое слово sweet.

Я хочу получить данные обеих строк в отдельных списках в JSON. Кто-нибудь может помочь?

Примечание. Я пробовал запрос в SQL Studio и получил две записи. Так что я уверен в этом 2 ряда!

1 Ответ

0 голосов
/ 09 сентября 2018

Вы возвращаетесь из цикла while

while(){
    retun Ok(response);
}

, поэтому возвращается после добавления первого элемента. Переместите его за пределы цикла while

while(){
 //do stuff
}
string response = JsonConvert.SerializeObject(baseResponse);
return Ok(response);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...