如何处理Node.js中的错误/异常?

时间:2016-05-13 07:58:38

标签: javascript node.js nodes microservices mariasql

我已经在Node.js中编写了代码,使用seneca微服务连接mariadb数据库,但我无法知道如何处理错误/异常并向用户显示正确的消息。所以请帮助我解决哪些类型的错误以及如何处理它。

这是我的代码

seneca.add({
  role: 'user',
  cmd: 'Authentication_Registration'
}, function(msg, respond) {
  //Check wheather user is exist or not
  /*try{*/

  con.query('Select * from RegistrationDemo where UserName= (:user) ', {
    user: msg.Username
  }, function(err, results) {
    if (err)
      throw err
    else {
      if (results.length != 0) {
        respond(false, {
          answer: "User Allready Exists"
        });
      } else {
        //If user is not exist enter the registration details into the table
        con.query('insert into RegistrationDemo(Name,UserName,DOB,Email,Password) values ((:name),(:user),(:dob),(:email),(:password)) ', {
          name: msg.Name,
          user: msg.Username,
          dob: msg.dob,
          email: msg.email,
          password: msg.password
        }, function(err) {
          if (err)
            respond(false, {
              answer: "Data not able to insert"
            });
          else {
            //insert 
            con.query('insert into Hash.user(UserName,PassWord) values((:user),(:pass))', {
              user: msg.Username,
              pass: msg.password
            }, function(err) {
              if (err) {
                respond(false, {
                  answer: "Data can't registered"
                });
                con.query('rollback');
              } else {
                respond(true, {
                  answer: "you are registered sucessfully"
                });
              }
            })
          }
        });
      }
    }
  })

  /*} /*catch(Error)
    {
        console.error("catch erro" + Error);
    }*/
});

seneca.act({
  role: 'user',
  cmd: 'Authentication_Registration',
  Name: 'asn',
  Username: 'asn@123',
  email: 'xxx@gmail.com',
  password: 'xxx',
  dob: '1993-09-23'
}, function(err, result) {
  if (err) return console.error(err)
  console.log(result.answer);
});

0 个答案:

没有答案