This website is now static html, I have no time to write anything and Wordpress has more security holes than a Swiss cheese, and so the migthy wget -m replaced the ugly php. For sure there will be problems with this new version, but that is life.
show hide sidebar
Some advices, read carefully:
Se vuoi essere alla moda ed avere un blog tutto tuo mi permetto di consigliarti dreamhost, se usi il codice DAT hai pure lo sconto (dettagli).



Ajax, BlogBabel API e mostrare alcune statistiche sul proprio blog (o almeno tentare di)

Siccome oggi era giunta l’ora di iniziare a capire perché tutti considerano sto Web2.0 così ficco, mi sono messo a studiare Ajax (mattone fondamentale di tutto quello che è 2.0). Incidentalmente ho anche scoperto che BlogBabel ha rilasciato non molto tempo fa delle API (no, non gli insetti) pubbliche.

Fondendo i due task assieme e raschiando dal fondo del barile le mie (poche) capacità di programmazione ho deciso di aggiungere delle statistiche (una a dire il vero) di BlogBabel in questo blog (se apri la sidebar dovresti trovarla).

Ipotizzando che mi interessi solo la posizione generale nella classifica di BlogBabel (e voglia il risultato in formato testo) mi basta usare un URL del tipo http://it.blogbabel.com/api/v1/blog/dat;a=rank&f=txt/.

La mia vena divulgativa si è appena esaurita e quindi vi sparo tra capo e collo tutto il codice javascript da mettere all’interno del campo <head> del vostro blog.

<script type="text/javascript">

//mi creo il mio bell'oggetto
HttpRequestvar receiveReq = getXmlHttpRequestObject();

//da dove prendo i dati (questo te lo spiego più avanti nel post)
var url = "http://dat.perdomani.net/dat.txt";

function getXmlHttpRequestObject() {
if (window.XMLHttpRequest) {
    return new XMLHttpRequest(); // Se sei uno bravo che non usa IE
 } else if(window.ActiveXObject) {
    return new ActiveXObject("Microsoft.XMLHTTP"); // Se non sei bravo
 } else {
    document.getElementById("blogbabel").innerHTML = "(passa a firefox se vuoi saperlo)"; //Se sei vecchio
 }
}

function  myBlogBabelPosition() {
 //Se l'XmlHttpRequest si degna di darci attenzione
 if (receiveReq.readyState == 4 || receiveReq.readyState == 0) {
 //Voglio una get asincrona dove ti dico io
   receiveReq.open("GET", url, true);
   //Appena sei pronto avvertimi che ti dico cosa fare
   receiveReq.onreadystatechange = handleRequest;
   //Speriamo non si perda per strada
   receiveReq.send(null);
 }

}

function handleRequest(){ if(receiveReq.readyState == 4){
  if(receiveReq.status == 200){
   //Scrivo la posizione
   document.getElementById("blogbabel").innerHTML = receiveReq.responseText;
  }
 }
}

A quanti, leggendo il codice, hanno subito storto il naso e mi avranno, con gran probabilità dato del deficiente, vorrei puntualizzare che le mie conoscenze di javascript sono evidentemente limitatissime e che, essendo io persona gentile e dotata di buone maniere, scarico la statistica blogbabel sul mio server (con un cronjob del tipo 0 */6 * * * wget -O dovelometto dadoveloprendo) ogni 6 ore. Evito così che OGNI pagina servita dal mio blog vada a fare una richiesta al server di BlogBabel (spero apprezzino la gentilezza) per una statistica che in fin dei conti cambia una volta al giorno.

Gli ultimi passi per far funzionare l’accrocchio sono quello di aggiungere l’attributo onload=”myBlogBabelPosition();” al tag body e, da qualche parte nella pagina, uno span con id “blogbabel” e senza testo tra il tag di apertura e chiusura.

Chissà se quello che ho fatto è il modo corretto di pensare Ajax e, ancor più importante, se non espongo il blog a problemi di sicurezza …

Chiaramente se vi interessa avere le statistiche nel vostro blog vi consiglio di usare il plugin di undolog o il nuovissimo di P|xeL o quello più nuovissimo ancora di undolog (ragazzi adesso basta però ;) (i plugins sono per wordpress ma facilmente portabili ad altre piattaforme, credo).

UPDATE: certo, sono cosciente del fatto che essendo le informazioni statiche e per giunta salvate sul mio server non serviva proprio scomodare ajax, però mi piaceva fare così e così ho fatto =) (che poi, a dire il vero, non ho neanche idea di come aprire un file da php …)

UPDATE2: se non volete usare il mio bel metodo con il crontab e volete, invece, rompere i coglioni al server di BlogBabel i dati aggiornati ad OGNI caricamento di OGNI pagina per OGNI visitatore del vostro blog allora usate codice tipo questo:

<span id="bb"></span>

<script type="text/javascript">
function show_rank(o){
  document.getElementById("bb").innerHTML = o.rank;
}
</script>
<script type="text/javascript" src="http://it.blogbabel.com/api/v1/blog/dat;a=rank&f=js&c=show_rank/"></script>

sparso come il prezzemolo un po’ qua e un po’ là nella pagina.

9 Risposte »

da lontano

  1. [...] Internet, Javascript, PHP, Rank, Sviluppo, WordPressGrazie alle segnalazioni di P|xel e Dat sono venuto a conoscenza delle nuove API messe a disposizione dal sito BlogBabel. Così ho [...]

    Pingback by undolog » Blog Archive » BlogBabel API: finalmente la beta — July 24, 2007 @ 8:51 am


da vicino

  1. Giovambattista Fazioli

    Grazie per la citazione e l’informazione…
    Sono contento che BlogBabel abbia aperto finalmente al mondo le API… appena posso farò un bel Upgrade al mio Plugin ;)

  2. Blog Admin dat

    non c’è di che :)

  3. P|xeL

    Sembra che nessuno di noi pensi ad altro stasera: http://www.dreamsworld.it/emanuele/2007-07-23/wordpress-plugin-blogbabel-rank-plus/ ;-)
    Ciao,
    P|xeL

  4. Blog Admin dat

    già, sarà il caldo che fa andare in pappa il cervello e allora si passano ore davanti lo schermo nella vana speranza che LCD ti abbronzi senza ustionarti (a differenza del sole).
    comunque ho aggiornato il post per segnalare il nuovo plugin
    ciao
    dat

  5. Giovambattista Fazioli

    Guardate qui: http://www.screencast.com/t/0PnxZbx_

    Peccato funzioni solo da locale!!!

  6. ludo

    Apprezziamo la gentilezza, e anche il fatto che ci sia qualcuno che usa le nostre API. :)

  7. Giovambattista Fazioli

    Fatto!!! Ecco quello nuovo in Flash!!!
    http://www.undolog.com/2007/07/24/blogbabel-api-finalmente-la-beta/

  8. Blog Admin dat

    @ludo
    credo che appena le api diventerranno ufficiali e non in beta ci sarà più di qualcuno interessato ad usarle … (io ad esempio tra un pò sostituirò il mio codice blog con quello di BeggiAndrea (potrei usare il rank di Pandemia ma non voglio strafare, all’inizio) =)

    @G.F.
    ho aggiunto nel post il link al nuovo plugin, per quello che può servire un link in un mio post …

RSS feed for comments on this post. TrackBack URI

Qui puoi lasciare un commento, non che ci tenga nè che mi interessi la tua opinione. Tu prova a scrivere qualcosa e poi vediamo ...

Line and paragraph breaks automatic, e-mail address never displayed, HTML allowed: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>

(required)

(required)


-
order buy buy buy