JQuery ошибка в ответе клиента сообщения - POST HTTP / 1.1 "400 - PullRequest
2 голосов
/ 16 октября 2019

Я не могу понять, что не так с моим кодом, и я не очень хорош с jQuery. Я пытаюсь построить форму HTML будет хранить данные автомобилей. Он основан на этой форме:

enter image description here

Исходный код HTML здесь .

Данные формы отправляются нанажмите кнопку в конце, чтобы вернуться к программе.

Я обновил эту форму с помощью каскадного производителя (proizvodjac в коде) и моделей автомобилей droplist на основе этого кода. Но это не работает.

Я продолжаю получать HTTP 400, что будет означать, что мой POST-вызов от клиента искажен.

Вот мои функции jQuery:

$(function () {

        var carsdata = {"alfaromeo":["mito","156","147","giulietta","159","166","146"],"audi":["a3","a4","a6","a5","80","a1","q3","a8","q5"],"bmw":["320","116","x3","316","318","118","530","x1","520","x5","525","330","120","323","serija 1"],"chevrolet":["spark","lacetti","captiva","aveo","cruze"],"citroen":["c4","c4 grand picasso","c3","c5","c4 picasso","xsara","berlingo","c2","xsara picasso","saxo","ds5","c1"],"fiat":["brava","bravo","panda","grande punto","stilo","punto","punto evo","doblo","500","tipo","uno","coupe"],"ford":["c-max","fiesta","focus","mondeo","fusion","ka","escort"],"honda":["civic","accord","cr-v"],"hyundai":["getz","i10","i20","atos","i30","coupe","elantra","accent","santa fe","ix35","tucson"],"kia":["rio","pro_cee'd","sportage","cee'd","pride","sorento"],"mazda":["3","2","323 f","626","6","cx-5","323","premacy","5"],"mercedes":["a-klasa","c-klasa","e-klasa","b-klasa","124"],"mercedes-benz":["e-klasa","clk-klasa","c-klasa","s-klasa","190","a-klasa","b-klasa","c t-model","ml-klasa","w 124","124"],"nissan":["qashqai","x-trail","note","primera","micra","juke","almera"],"opel":["corsa","astra","zafira","meriva","vectra","insignia","mokka","tigra","combo","astra gtc","kadett"],"peugeot":["308","207","206","306","106","307","208","406","508","407","partner","3008","405"],"renault":["thalia","clio","scenic","grand scenic","kangoo","captur","megane grandtour","megane","laguna","5","megane break","twingo","modus","kadjar","megane classic","espace","megane scenic","megane coupe","megane sedan"],"seat":["toledo","leon","ibiza","altea","cordoba"],"skoda":["fabia","octavia","120","superb","felicia","rapid"],"smart":["fortwo"],"toyota":["corolla","yaris","auris","avensis","rav 4","land cruiser"],"vw":["polo","golf v","golf iv","golf vii","passat","golf vi","jetta","passat variant","caddy","sharan","tiguan","golf variant","golf ii","vento","golfplus","golf iii","bora","touran","touareg","up!"]};

        var proizvodjac = $('<select id="proizvodjac"></select>');
        var model = $('<select id="model"> </select>');
        $.each(carsdata, function(item, key) {
            proizvodjac.append('<option >' + item + '</option>');
        });
        $("#containerProizModel").html(proizvodjac);
        $("#proizvodjac").on("change", function(e) {
            var item;
            var selected = $(this).val();
            if (selected === "alfaromeo") {
                item = carsdata[selected];
                } else {
                item = carsdata[selected];
            }
            $(model).html('');
            $.each(item, function(item, key) {
            model.append('<option >' + key + '</option>');
                });
            });

            $("#containerProizModel").append(model);

        $("button#predict").click(function(e){
            e.preventDefault();
            /*Get for variabes*/
            var kilometraza = $("#kilometraza").val(), godina_proizvodnje = $("#godina_proizvodnje").val();
            var snaga_motora = $("#snaga_motora").val(), vrsta_goriva = $("#vrsta_goriva").val();           

            /*create the JSON object*/
            var data = {"kilometraza":kilometraza, "godina_proizvodnje":godina_proizvodnje, "proizvodjac":proizvodjac, "model":model, "snaga_motora":snaga_motora, "vrsta_goriva":vrsta_goriva}
            /*send the ajax request*/
            $.ajax({
                method : "POST",
                url : window.location.href + 'api',
                data : $('form').serialize(),
                success : function(result){
                    var json_result = JSON.parse(result);
                    var price = json_result['price'];
                    swal('Predviđena cijena auta je '+price+' kn', '','success')
                },
                error : function(){
                    console.log("error")
                }
            })
        })
        })

Комментарии и пояснения находятся вcode.

На стороне сервера:

Сервер ожидает словарь user_input, созданный из переменных, возвращаемых запросом POST. Вот как выглядит метод API:

@app.route('/api',methods=['POST'])
def get_delay():
    result=request.form
    proizvodjac = result['proizvodjac']
    model = result['model']
    godina_proizvodnje = result['godina_proizvodnje']
    snaga_motora = result['snaga_motora']
    vrsta_goriva = result['vrsta_goriva']
    kilometraza = result['kilometraza']


    user_input = {'proizvodjac':proizvodjac, 
                  'model':model,
                  'godina_proizvodnje':godina_proizvodnje,
                  'snaga_motora':snaga_motora, 
                  'vrsta_goriva':vrsta_goriva, 
                  'kilometraza':kilometraza
             }

    print(user_input)    
    a = input_to_one_hot(result)
    price_pred = gbr.predict([a])[0]
    price_pred = round(price_pred, 2)
    return json.dumps({'price':price_pred});

Ошибка из консоли разработчика Google Chrome:

enter image description here

который указывает на: enter image description here

РЕДАКТИРОВАТЬ 1:

Я не знаю, как передать производяц и модель в функцию onClick. Посмотрите, что происходит в точке останова: enter image description here

XHR на вкладке Сеть:

enter image description here

HTML-формазаполнение данными ОК, только производитель и модель не передаются в onClick:

enter image description here

РЕДАКТИРОВАТЬ 2: Приближение к решению. Я добавил:

var proizvodjac = $("#proizvodjac").val()
                var model = $("#model").val()

как предложено, и теперь все переменные успешно переданы! Но я все еще получаю ошибку 400, так как последний вызов ajax POST застревает где-то ..

enter image description here

РЕДАКТИРОВАТЬ 3: изменено с

data : $('form').serialize()

до

data = data 

Метод AJAX получает все в порядке:

enter image description here

Тем не менее это не такработа.

1 Ответ

1 голос
/ 16 октября 2019

Здесь есть две основные проблемы:

1) вы неправильно получаете значения из двух ваших полей. Вам нужно добавить

var proizvodjac = $("#proizvodjac").val()
var model = $("#model").val()

внутри функции $("button#predict").click(function(e){.

2) Вы собираете все эти значения и помещаете их в переменную data ... но затем выничего с этим не делаем. Ваш AJAX-запрос настроен следующим образом в зависимости от того, какие данные отправлять:

data : $('form').serialize()

Функция serialize () автоматически собирает все необработанные данные из полей в ваших тегах <form>,В вашем сценарии, если вы хотите отправить пользовательский набор данных (а не просто содержимое формы как есть) в соответствии с вашим data объектом, вам просто нужно изменить это значение на

data: data

поэтому он отправляет информацию из этого объекта в запросе POST.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...