Как зациклить массивы с помощью node.js request () - PullRequest
0 голосов
/ 15 марта 2019

Я перешел от передачи отдельных значений в мой API узла к передаче нескольких значений, и API прекратил отправлять ответ обратно.

Пример отдельных значений для полей:

tracking: "123", // Only one tracking number
carrier: "usps" // Only one carrier code

Пример нескольких значений для полей:

tracking: [ '9361289691090998780363', '784644233417' ],
carrier: [ 'usps', 'fedex' ]

Я думаю, что мне нужно добавить какой-то цикл, но я не могу понять, как это сделать, и при этом я не знаю, какова правильная терминология, чтобы искать это. Это связано с Aync? Я потерян.

request(options, function (error, response, body){});

Вот мой код. Любая помощь / дополнительная информация была бы признательна за понимание того, что я делаю неправильно.

html.js

// These are sent over in an AJAX call //
var trackingNumber = ['9361289691090998780363', '784644233417'];
var carrierCode = ['usps', 'fedex'];

controller.js

app.get("/api/tracking/retrieve", (req, res) => {

    var carrier = req.query.carrier;
    var tracking = req.query.tracking;

    console.log('carrier array', carrier);
    console.log('tracking array', tracking);

    var options = {
        method: "GET",
        url: 'https://api.example.com/v1/tracking',
        qs: { carrier_code: carrier, tracking_number: tracking },
        headers:
            {
                'api-key': process.env.SECRET_KEY_SE,
                'accept': 'application/json'
            }
    }

    console.log("Url: ", req.url);
    console.log("Query: ", req.query);
    // res.send("ok");

    request(options, function (error, response, body) {
        if (!error && response.statusCode == 200) {
            console.log('BODY', body)

            var trackingData = JSON.parse(body)
            console.log('trackingData: ', trackingData);
            table = 'tracking_table';
            col = [
                'user_id',
                'tracking_number',
                'carrier_code',
            ];

            val = [
                user_id,
                trackingData.tracking_number,
                options.qs.carrier_code,
            ];

            main.create(table, col, val, function (data) {
                res.json({
                    id: data.insertId,
                    user_id: user_id,
                    tracking_number: data.tracking_number,
                    carrier_code: data.carrier_code,
                });
            })
        }
    })

})

1 Ответ

0 голосов
/ 15 марта 2019

Из вашего контроллера я могу видеть, что как только вы получаете запрос, вы отправляете ответ обратно.Как вы можете отправить ответ снова?

Я прокомментировал ваш res.send ('ok'), и он работает.

app.get("/api/tracking/retrieve", (req, res) => {
    var carrier = req.query.carrier;
    var tracking = req.query.tracking;
    console.log('carrier array', carrier);
    console.log('tracking array', tracking);
    var options = {
        method: "GET",
        url: 'https://api.example.com/v1/tracking',
        qs: { carrier_code: carrier, tracking_number: tracking },
        headers:
            {
                'api-key': process.env.SECRET_KEY_SE,
                'accept': 'application/json'
            }
    }
    console.log("Url: ", req.url);
    console.log("Query: ", req.query);
    // res.send("ok"); <--
    request(options, function (error, response, body) {
        if (!error && response.statusCode == 200) {
            console.log('BODY', body)
            var trackingData = JSON.parse(body)
            console.log('trackingData: ', trackingData);
            table = 'tracking_table';
            col = [
                'user_id',
                'tracking_number',
                'carrier_code',
            ];
            val = [
                user_id,
                trackingData.tracking_number,
                options.qs.carrier_code,
            ];
            main.create(table, col, val, function (data) {
                res.json({
                    id: data.insertId,
                    user_id: user_id,
                    tracking_number: data.tracking_number,
                    carrier_code: data.carrier_code,
                });
            })
        }
    })
});
...