집 >데이터 베이스 >MySQL 튜토리얼 >내 Node.js 로그인 API가 Promise와 작동하지 않는 이유는 무엇입니까?
Node.js 로그인 API가 오해로 인해 예기치 않은 동작을 보이고 있습니다. Promise가 비동기 작업과 상호 작용하는 방식에 대해 설명합니다. 각 문제를 살펴보겠습니다.
findUser() 함수가 Promise를 반환하지 않습니다. 대신, 데이터베이스 쿼리가 비동기적이고 실행하는 데 시간이 걸리기 때문에 즉시 정의되지 않은 값을 반환합니다. 이 문제를 해결하려면 쿼리가 완료될 때 호출되는 콜백 함수를 query() 메서드에 전달해야 합니다.
me.findUser = function(params, res) { var username = params.username; return new Promise(function (resolve, reject) { pool.getConnection(function (err, connection) { if (err) { reject(err); } else { connection.query('select ...', [username], function (err, rows) { connection.release(); if (!err) { resolve(rows); } else { reject(err); } }); } }); }); }
프로미스의 Reject() 메서드가 호출되지 않기 때문에 오류 핸들러가 트리거되지 않습니다. 코드에서는 오류가 발생하면 데이터베이스 쿼리에 대한 콜백에서 false를 반환합니다. 대신 오류가 있는 Promise를 거부()해야 합니다.
me.findUser = function(params, res) { // ... return new Promise(function (resolve, reject) { // ... connection.query('...', [username], function (err, rows) { connection.release(); if (!err) { resolve(rows); } else { reject(err); } }); }); }
다음은 로그인 경로 파일의 수정된 버전입니다. 약속을 사용합니다 적절하게:
module.exports = function(app) { app.post('/login/', async function(req, res, next) { try { // Find user in database var rows = await loginM.findUser(req.body, res); // Do something with the data var result = await loginC.doSomething(rows); console.log("Success"); } catch (err) { console.log("Failed: " + err.message); } }); }
Promise를 사용하면 로그인 API의 각 단계가 순서대로 실행되도록 할 수 있습니다. Wait 키워드는 코드가 진행하기 전에 Promise가 해결될 때까지 기다리도록 하여 다음 단계가 이전 단계의 데이터에 액세스할 수 있도록 보장합니다. 또한 try/catch를 사용하면 프로세스 중에 발생할 수 있는 모든 오류를 처리할 수 있습니다.
위 내용은 내 Node.js 로그인 API가 Promise와 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!