попробуйте поймать внутри Axios в тогда метод в узле JS - PullRequest
0 голосов
/ 11 июня 2019
  • после нажатия на нижеприведенный вызов API я получаю ошибки. (node:5548) UnhandledPromiseRejectionWarning: Unhandled promise rejection (rejection id: 1): Error: Can't set headers after they are sent. (node:5548) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.
    • поэтому я вставил try catch внутри моего метода then, но все равно не могу перехватить ошибки внутри моего catch.
    • Я отладил, поставив консоль console.log("try catch error--->", error), но все равно ничего не помогло
    • Не могли бы вы сообщить мне, правильно ли я добавил попробовать и поймать внутри моего метода then.
    • предоставив мой фрагмент кода ниже
   axios.get(AppConstants.GET_JWT_TOKEN_URL, {
        auth: {
            username: credentials.auth.racfId, password: credentials.auth.password
        }
    })
        .then((jwtResponse) => {
            console.log("jwt then----->", jwtResponse.data.jwt);
            var jwtToken = `Bearer ${jwtResponse.data.jwt}`;
            //   var jwtToken = `Bearer ewefewehjefwwe wehwefwefwef uih uihu`;
            console.log('then formatUrl --->', formatUrl);

            axios.get(formatUrl, {
                headers: {
                    "Authorization": jwtToken, "Content-Type": 'application/json'

                }
            })

                .then((response) => {
                    try {
                        console.log("sports suceess then0--->");
                        const file = Buffer.from(response.data.content, 'base64');
                        const fileType = mime.contentType(response.data.contentInfo.fileType);
                        const fileExtension = response.data.contentInfo.fileType.toLowerCase();
                        const fileName = `filename=${response.data.contentInfo.id}.${fileExtension}`;
                        console.log("sports suceess fileName--->", fileName);
                        ResponseUtil.callService(res, url);

                        res.send({});
                    }
                    catch (error) {
                        console.log("try catch error--->", error)
                        const errorMessage = error.response.data.message;


                    }

                })


                .catch((e) => {
                    console.log("e catch sports0--->", e);
                    console.log("e.message catch sports0--->", e.message);

                    console.log("catch sports--->", e.response);

                    if (e.response) {
                        return res.status(e.response.status).send(e.response.data);
                    }
                    res.status(500).send(e.message || 'Something wrong');
                });



        });

журналы

sports suceess then0--->

sports suceess fileName---> ioreioreio=erierioerioerio
  callService ===>  /erpoperoperop/rejklerklkler
  else if responseutil.jsURL ===>  http://players/erpoperoperop/rejklerklkler
  URL ===>  http://players/erpoperoperop/rejklerklkler
express deprecated res.send(status, body): Use res.status(status).send(body) instead server\services\utils\ResponseUtil.js:56:30
(node:5548) UnhandledPromiseRejectionWarning: Unhandled promise rejection (rejection id: 1): Error: Can't set headers after they are sent.
(node:5548) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.

1 Ответ

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

Есть несколько проблем с этой реализацией. Первая проблема заключается в том, что вы забыли вернуть свои обещания, чтобы они применялись к цепочке обещаний. Если вы не вернете обещание, ошибки не будут распространяться вверх по цепочке обещаний, что противоречит цели обещаний. Вторая проблема заключается в том, что вы пытаетесь отправить ответ дважды, один раз в ResponseUtil.callService(res, url) и в другой раз непосредственно после этого (например, res.send({});).

Ошибки консоли указывают на обе эти ошибки:

1) Невыполнение обещаний

(узел: 5548) UnhandledPromiseRejectionWarning: необработанное отклонение обещания (идентификатор отклонения: 1): ошибка: невозможно установить заголовки после их отправки.

2) Повторный вызов res.send

экспресс устаревший res.send (статус, тело): используйте res.status (статус) .send (тело) вместо server \ services \ utils \ ResponseUtil.js: 56: 30


Я собираюсь сделать предположение, что ResponseUtil.callService(res, url) возвращает обещание ответить на этот вопрос, так как кажется, что это так.

axios.get(AppConstants.GET_JWT_TOKEN_URL, {
    auth: {
        username: credentials.auth.racfId,
        password: credentials.auth.password
    }
}).then((jwtResponse) => {
    // Return the promise from get so it is applied to the promise chain
    return axios.get(formatUrl, {
        headers: {
            "Authorization": `Bearer ${jwtResponse.data.jwt}`,
            "Content-Type": 'application/json'

        }
    }).then((response) => {
        const file = Buffer.from(response.data.content, 'base64');
        const fileType = mime.contentType(response.data.contentInfo.fileType);
        const fileExtension = response.data.contentInfo.fileType.toLowerCase();
        const fileName = `filename=${response.data.contentInfo.id}.${fileExtension}`;
        // Return the promise from call service so it is applied to the promise chain
        return ResponseUtil.callService(res, url);
    });
}).catch((e) => {
    // Catch any error that occurred in the promise chain...
    if (e.response) {
        return res.status(e.response.status).send(e.response.data);
    }
    return res.status(500).send(e.message || 'Something wrong');
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...