Mobile computing/2005-2006
v6EU34 <a href="http://zbjrqswxovjc.com/">zbjrqswxovjc</a>, [url=http://wnripfgiuuqg.com/]wnripfgiuuqg[/url], [link=http://algopfdaeexl.com/]algopfdaeexl[/link], http://hvnxchyhworw.com/
Indice
- 1 Diario del corso
- 1.1 Lezione di Martedì 4-10-05
- 1.2 Lezione di Venerdì 7-10-05
- 1.3 Lezione di Martedì 11-10-05
- 1.4 Lezione di Venerdì 14-10-05
- 1.5 Lezione di Martedì 18-10-05
- 1.6 Lezione di Venerdì 21-10-05 SOSPESA
- 1.7 Lezione di Martedì 25-10-05
- 1.8 Lezione di Venerdì 28-10-05
- 1.9 Lezione di Venerdì 4-11-05
- 1.10 Lezione di Martedì 8-11-05
- 1.11 Lezione di Venerdì 11-11-05
- 1.12 Lezione di Martedì 15-11-05
- 1.13 Lezione di Venerdì 18-11-05
- 1.14 Lezione di Martedì 22-11-05
- 1.15 Lezione di Venerdì 25-11-05
- 1.16 Lezione di Martedì 29-11-05
- 1.17 Lezione di Venerdì 2-12-05
- 1.18 Lezione di Martedì 6-12-05 SOSPESA
- 1.19 Lezione di Venerdì 9-12-05 SOSPESA
- 1.20 Lezione di Martedì 13-12-05
- 1.21 Lezione di Venerdì 16-12-05
Diario del corso
Lezione di Martedì 4-10-05
Un sito che percorrerà molti degli argomenti del corso è questo.
Argomenti trattati nella lezione di oggi:
- Abbiamo visto a grandi linee l'evoluzione dell'hardware ,che ha portato a:
- riduzione delle dimensioni delle macchine;
- evoluzione rapporto persona/macchina (molte persone singolarmente lavorano con un calcolatore,per approdare ai PC e infine più macchine al servizio di una sola persona);
- Evoluzione di Internet;
Abbiamo definito:
- Traditional Computing: capacità di calcolo classico;
- Mobile Computing: la mobilità è la caratteristica principale;
- Pervasive Computing: implementazione di funzioni di calcolo e comunicazione in oggetti;
- Ubiquitous Computing: una combinazione dell'aspetto mobile e pervasive;
- Disappearing Computing: l'embeddedness dei dispositivi tende a farli divenire oggetti della vita quotidiana,regiscono ad eventi in relazione all'utente e al suo contesto;
Il Mobile Computing,per sua natura,è e sarà oggetto di forti novità e sviluppo,sia per quanto riguarda sistemi operativi,linguaggi, protocolli, architetture, algoritmi ed interfacce;
Parimenti presenta altresì difficoltà non indifferenti,quali la rapida evoluzione con il conseguente invecchiamento precoce delle tecnologie,notevole competizione,sistemi operativi immaturi e instabili e una grande eterogeneità hardware,software e di protocolli in circolo.
Abbiamo visto le sue applicazioni a livello lavorativo/aziendale/quotidiano e i ruoli professionali coinvolti in questo settore.
- Lista degli operatori di reti mobili: qui
Lezione di Venerdì 7-10-05
Abbiamo trattato la classificazione dei dispositivi secondo certe caratteristiche:
- I/O: schermo,touchscreen,tastiera,slot di espansione,ecc..
- Connettività: globale,locale;
- Risorse di calcolo: CPU,RAM,ecc..
- Autonomia: batteria;
- Supporto applicazioni: JVM,.NET Compact Framework,ecc..
- Supporto multimediale: audio,video,ecc...
PDA(Personal Digital Assistent):
- orientati alla gestione/scambio di dati;
- supporta solo connettività locale;
PDA-phones:
- supporto UMTS per scambio dati;
- risorse di calcolo inferiori ai PDA;
- frequentemente utilizzati in USA;
- usato molto e principalmente per e-mail;
- ha una tastierina;
- più vicini ai laptop che ai dispositivi mobili;
- riconoscitore vocale e di scrittura;
- costo elevato;
- connessione locale integrata;
- SO microsoft: il costo elevato e la mancanza di applicazioni utili non ha fatto decollare il loro sviluppo,deludendo Micro$oft;
- Esempio di utilizzo di PDA-phones con riconoscimento vocale in aula;
- analisi dei dispositivi in termini di vendite sul mercato:
- frammentazione del mercato;
- assenza di un leader dominante;
- frequenti novità;
- convergenza tra PDA e smart-phones;
- supporto navigazione GPS,suite Office,ecc..
- si riduce il numero di Sistemi operativi e di piattaforme di sviluppo;
- Introduzione ai sistemi operativi:
- differenze tra quelli generici e quelli per mobili;
- molto importante l'aspetto di risparmio delle risorse.
- I più usati:
- PalmOS(il più stabile secondo il prof);
- SymbianOS (orientato alla telefonia);
- Windows Mobile(il meno stabile secondo il prof.);
- OS in java e Linux: percentuali ridotte sul mercato;
- Cosa vuol dire OEM
Lezione di Martedì 11-10-05
- Osservazione dell'architettura dei sistemi operativi per mobili,in particolare:
- Windows Mobile: è un OS per dispositivi mobili(PDA e smart phones),dipendente da componenti di Windows CE,con le seguenti caratteristiche principali:
- struttura modulare;
- multitasking(supporta sottoinsieme delle Win32 API e .NET)
- possibilità di sviluppo attraverso piattaforme di sviluppo comuni anche per i desktop:gli ultimi due punti rendono agibile il compito di sviluppatori che non devono affrontare una lunga curva di apprendimento;
L'ultima versione è la 5.0,sincronizzazione dei dati pc/dispostivo mobile tramite ActiveSync
- PalmOS:
- ha dominato per molto tempo il mercato dei PDA;
- dalla V5 è anche multitasking e multithreading
- le applicazioni possono includere Conduits,cioè software di sincronizzazione dati pc/dispositivo simili per funzione al corrispettivo Microsoft ActiveSync
- versioni principali: Garnet e Cobalt
- supporto telefonia,Wifi,Bluetooth,UI migliorata;
- Symbian:
- Linux:
- poco supportato dai produttori ma diffuso sui sistemi embedded fissi;
- sfrutta QT Embedded come piattaforma di sviluppo per le GUI e supporta java(come Esmertec);
- Windows Mobile: è un OS per dispositivi mobili(PDA e smart phones),dipendente da componenti di Windows CE,con le seguenti caratteristiche principali:
Pre-lezione: si è speso qualche parola in merito agli scioperi degli insegnanti riguardo la protesta su D.legisl. della Moratti:
- Posizione ricercatori DICO,ecc.. qui
Connettività locale
WPAN | WLAN |
---|---|
copertura inferiore ai 10m | copertura inferiore ai 100m |
Rimpiazza cavi | estensione o rimpiazzo di una rete locale |
throughput fino a 4 Mbps | fino a 54 Mbps |
standard IrDA,Bluetooth,802.15 | 802.11a/b/g,HIPERLAN/2 |
- Bluetooth:
- non richiede linea diretta(cioè senza ostacoli nel mezzo)per la comunicazione;
- copertura fino a 10m,amplificabile fino a 100m;
- usa lo spettro 2.4GHz con il frequency hopping; vedere anche qui
- scopre automaticamente altri dispositivi nel raggio di portata;
- possibilità di crittare la comunicazione,più è grande la chiave più lenta sarà la comunicazione;alcune tecniche d'attacco sono:
- BlueJacking: vedere anche qui;
- Bluesnarfing;
- permette connessioni simultanee;
- la tecnologia bluetooth permette il formarsi di alcuni tipi di rete:
- piconet:rete wireless di 2 o più dispositivi connessi(fino ad 8);rapporto master/slave fra i dispositivi comunicanti;
- rete ad hoc: costituita da al massimo 8 dispositivi,òa quale non necessita di amministrazione e preconfigurazione,in cui c'è una comunicazione diretta di un dispositivo con gli altri;Vedere http://en.wikipedia.org/wiki/Ad-hoc_network
- scatternet: connessione di più piconet con più di 8 dispositivi,dove la comunicazione diretta avviene all'interno delle piconet;
- IrDA:
- standard per trasmissione di dati tramite connessione ad infrarossi;
- serve linea diretta di comunicazione;
- raggio di portata ridotto(1-2m);
- basso costo;
- supporto comunicazione bidirezionale;
- thoughput da 9.3 Kbps fino a 4 Mbps;
- 802.15:
- specifica dell'IEEE per creare un ostandard per WPAN;
- simile al BLuetooth;
- è ancora in progress;
- WLAN:
- configurazione ad hoc(la più semplice,non richiede amministrazione o preconfigurazione,non richiedono Access Point,poichè gli adattatori comunicano direttamente fra loro);
- può essere ampliata dagli Access Point,che possono anche eventualmente fornire il collegamento alla rete cablata;
- standard:
- 802.11:
- 802.11/b(WiFi):usa lo spettro dei 2.4GHz con la tecnica DSSS;è la più popolare. Throughput massimo di 11 Mbps,scende con l'allontanarsi dall'AP. Può penetrare barriere anche spesse,più facilmente rispetto alle alte frequenze. Lo svantaggio è che usa una frequenza molto usata e può portare a congestioni/interferenze nella comunicazione. L'implementazione del roaming fra gli AP stessi,è a carico degli AP. Schemi di sicurezza tramite WEP
- 802.11a usa l'OFDM e la frequenza 5GHz,frequenza limitata in alcuni paesi. Throughput fino a 54 Mbps,buono per scambio di grossi file,accesso veloce ad internet e per applicazioni multimediali. Ha un raggio di copertura ridotto,per mantenerlo largo servono molti più AP rispetto alla 802.11b. Non è compatibile con la versione b.
- 802.11g: compatibile con la versione b,comunica sulla sua stessa frequenza con il DSSS,ma è in grado di raggiungere tassi di trasmissione fino a 54 Mbps usando l'OFDM sempre all'interno della banda a 2.4 GHz. Quindi gli AP dei due tipi saranno i ngrado di comunicare. Per raggiungere il tasso di 54 Mbps entrambe le reti devono essere di tipo g.
- 802.11:
- WiMAX:estensione del WiFi a raggio chilometrico per la realizzazione di WMAN
- UWB:tecnologia a corto raggio ma a banda larga,con precedenti militari;
Differenza tra FHSS,DSSS e OFDM
La tecnica FHSS usa una banda portante stretta che cicla rapidamente le frequenze. Sia il mittente sia il destinatario conoscono il modello di cambio di frequenza usato. L'idea è avere sempre a disposizione una frequenza su cui scambiarsi i dati,altrimenti i dati vengono rispediti. Quindi attraverso una gusta sincronizzazione si ottiene un canale unico attraverso il quale l'informazione viene veicolata. Al resto del mondo,non essendo sincronizzato con la loro modalità di collegamento e scambio di frequenze,tutto ciò appare come raffiche di rumori. Si ha un throughput massimo di 1 Mbps.
La tecnica DSSS sparge il segnale lungo una banda larga di frequenze radio simultaneamente. Ogni bit trasmesso ha un bit di modello ridondante chiamato chip,il quale più è lungo è più è affidabile il reperimento dei dati. La maggiore lunghezza dei bit richiede però più banda. Chi non si aspetta i lsegnale lo riceve come un rumore a banda larga di debole potenza e viene rifiutato. E' una tecnica quindi che richiede più potenza dell'FHSS ma incrementa il tasso di trasmissione dei dati fino a 2 Mbps.
OFDM trasmette i dati in parallelo,al contrario delle tecniche precedenti,proteggendo meglio i segnali dalle interferenze. Ha un'altissima efficienza di spettro,cioè più dati di quanti ce ne possano stare possono essere trasmessi su una porzione ridotta di banda. Di contro la sua implementazione è più difficile e consuma grandi quantità di potenza.
Lezione di Venerdì 14-10-05
Connettività geografica
- WWAN:
- l'accesso a queste reti comporta un contratto con delle compagnie,al contrario delle WLAN e WPAN;
- non operano su frequenze libere,bisogna pagare lo spettro per usarlo;
- provvedono copertura wireless nazionale e spesso internazionale per comunicazione voce/dati;
Tipi di reti
- 1G:
- Costruite alla fine degli anni '70(USA) e ai primi degli '80(Europa);
- reti analogiche per trasmissione vocale;
- soffrivano di alti livelli d'interferenza,handoff scadenti,capacità ridotte e assenza di sicurezza;
- dispotivi abbastanza larghi da permettere l'integrazione dei ricevitori radio per captare il segnale analogico.
- 2G:
- reti digitali a commutazione di circuito,sviluppate nei primi anni '90;
- qualità servizi vocali migliorata,aggiunta servizi di base per la trasmissione di dati( ad un tasso variabile tra 9.6 e 19.2 Kbps);
- servizi voicemail,attesa di chiamata,identificazione del chiamante,comunicazione a 3;
- capacità maggiorate,permettendo a più utenti di comunicare sullo stesso spettro;
- Sicurezza notevolmente irrobustita ;
- sistemi che ne fanno parte: TDMA,CDMA,GSM,PDC(incompatibili fra loro,a volte anche fra lo stesso tipo di rete a causa di differenti frequenze. Per questo sono disponibili dispositivi dual-tri band,che permettono lo switch di frequenza,quindi anche il roaming);
- 2.5G:
- sistemi a commutazione di pacchetto;
- trasferimento dati innalzato fino a 144 Kbps(in realtà fino a 56 Kbps);
- l'upgrade dalla 2G richiede solo un aggiornamento software,non hardware,perchè si sfruttano ancora le reti cellulari esistenti e si gettando le basi per la 3G;
- le applicazioni WAP possono disporre di grafica e qualche funzionalità multimediale,ed essendo le reti GPRS simili alle LAN,permettono di costruire applicazioni alloo stesso modo di come le farebbero per una rete Ip-based,tenendo conto delle limitazioni del dispositivo;
- GPRS,CDMA2000 1x appartengono a questa generazione;
- maggiore efficienza nell'uso dello spettro nella condivisione di connessioni fra più utenti sia per scambio dati sia per la comunicazione vocale;
- capacità always on che permettono all'utente di rimanere collegato alla rete senza pagare a tempo il collegamento,permettendo anche il servizio di push dei dati;
- 3G:
- Vi appartengono WCDMA/UMTS,CDMA2000,EDGE;
- tasso di spedizione dei dati maggiore,è tanto più alto quanto più si è fermi,e decrescere con la velocità che prendiamo(tipicamente 384 Kbps);esso comunque dipende molto anche dalla distanza dalla Base Station,tanto più si è distanti tanto più difficilmente si ottengono velocità di trasferimento dati veloci;
- i dispositivi 3G hanno il supporto per contenuti multimediali,schermi ad alta risoluzione,OS mobili per sofisticate applicazioni client-side;
- QoS aumentata;
Protocolli
- GSM:
- la tecnologia 2G più usata al mondo;
- tecnologia a commutazione di circuito basata su TDMA;
- alta qualità della voce,capacità di roaming internazionale;
- frequenze europee su cui opera: 900/1800 MHz,1900 MHz Nord America;
- trasferimento dati fino a 9.6 Kbps tramite CSD(abbastanza per sms e WAP browsing,inadeguato per applicazioni di altro tipo); per ovviare a ciò è stata introdotta la tecnologia HSCSD(che è sempre circuit switched),che permette di usare in una singola connessione segmenti di tempo multipli per il trasferimento di dati fino a 28.8 Kbps(secondo il libro di riferimento per il corso,fino a 57.6 Kbps) ;
- tre componenti principali:
- Mobile station(telefonino e SIM);
- BSS(Base Station Subsystem): responsabile di gestire il traffico fra il dispotivio mobile e il Network Switching Subsystem. Le sue componenti sono il BTS e il BSC.
- Network Subsystem: realizza la comunicazione fra stazioni-mobili o fra mobili-mobili,gestendone le autenticazioni;le sue componenti sono l'HLR,VLR,l'AUC ,l'EIR e l'MSC.
- servizi
- Canali di controllo:
- BCCH ( Broadcast Control Channel ): canali che trasportano informazioni di interesse generale. Sono trasmessi in modo monodirezionale downlink (da BTS a MS) punto-multipunto. Per ciascuna cella il canale BCCH trasporta informazioni a tutti gli utenti serviti da quella BTS. Trasmesso in continuazione e in modo downlink. E' costituito da 184 byte che trasportano numerosi parametri, tra i quali: l'identità della cella (Cell Identity), dell'area di localizzazione (Local Area Code) dell'operatore di rete (MCC e MNC), oltre ai parametri richiesti dall'algoritmo di Frequency-Hopping.
- CCCH: canale logico trasmesso in entrambe le direzioni, il quale viene utilizzato quando l'utente non ha ancora allocato le proprie risorse sulla cella (es. in fase di primo accesso alla rete o in fase di riselezione di cella).
L'evoluzione porta ad aumentare la banda di trasferimento dei dati,poichè GSM assolve il suo dovere per quanto riguarda la voce ma non per i dati(lentezza,costo);
- GPRS:
- tecnologia 2.5G;
- introduce capacità di commutazione di pacchetto alle reti wireless;
- è un upgrade della tecnologia GSM e TDMA,permette quindi il roaming fra reti GPRS e GSM/TDMA;
- bit rates di trasferimento dati più alti(fino a 115 Kbps teorici,40 Kbps reali);
- capacità always on;
- opera sulle stesse frequenze delle reti GSM;
- tariffazione a pacchetto invece che a tempo,paghi per quel che richiedi,per dati trasferiti.
- il traffico inviato da una stazione mobile viene inviato ad un Base Station Subsystem,il quale smista i pacchetti IP verso l'SGSN(analogo all'MSC/VLR per GSM). Una stazione mobile attiva un PDP context con il suo SGSN.Quest'ultimo gli fornisce indirizzo IP,un QoS,un indirizzo di GGSN. La Mobile station specifica il GGSN da usare,che verrà specificato come APN. L'SGSN risolve l'APN nel corrispondente indirizzo IP,e incapsula i pacchetti IP tramite il protocollo GTP. Il GTP instrada i pacchetti fino ad un gateway GGSN. Questo consulta l'HLR per stabilire la posizione della mobile station,riconverte i pacchetti in IP instradandoli in Internet o Intranet. Nel caso di roaming il gateway comunica con un altro GGSN di un altro operatore;
- la convivenza tra GSM e GPRS si evince anche dai tipi di classi in cui vengono ripartiti i dispositivi mobili:
- A: terminali in grado di trattare voci e trasmissione di dati allo stesso tempo, Richiede due trasmettitori.
- B: trattano entrambe le modalità come nel precedente ma non contemporaneamente. Basta u nsolo trasmettitore;
- C: trattano o solo la voce o solo la trasmissione dati;
- vedi architettura in ampio dettaglio;
- UMTS:
- è la versione europea del WCDMA;
- usa il DSCDMA;
- progettato per essere l'upgrade delle reti EDGE/GPRS,operando alla frequenza di 2GHz,con data rates fino a 2Mbps;
- richiede copertura a differenza dell'EDGE e del GPRS,quindi sono tecnologie che lavorano a fiano,dove non arriva una c'è l'altra,tramite handoff verso differenti tipi di rete,al massimo si comunicherà a livelli più bassi di data rate;
- EDGE:
- tecnologia che permette alle reti GSM di offrire servizi 3G all'interno delle frequenze esistenti. TDMA o GSM/GPRS può venire portata all'EDGE col minimo impatto;
- tecnologia a banda stretta,formata da canali a 200 KHz,non richiede una licenza 3G,permettendo che influisca poco sui costi;
- data rates fino a 384 Kbps,più tipicamente fra 75/150 Kbps;
- è anch'essa una tecnologia basata sulla commutazione di pacchetti;
Glossario
- circuit switching(abbreviato qui con CS) Vs packet switching(PS): in breve,CS lavora bene per la comunicazione vocale dove c'è un flusso costante di dati trasferiti,richiedono connessioni dedicate. I dati devon oseguire una rotta precisa.;PS sono efficienti per la comunicazione di dati,dove avviene spesso a raffiche,non richiedono connessioni dedicate,permettendo a più utenti di condividere una singola connessione per massimizzare lo spettro. I pacchetti non devono seguire una rotta precisa, scegliendo il path ottimale.
- cella: area geografica che ottiene copertura wireless da una base station. L'area di copertura dipende dal protocollo di rete,dalla potenza del segnale e ostacoli. Più ci si allontana dalla base station più il segnale s'indebolisce. Il suo raggio vara da 1 a 40 Km. Per le WWAN celle multiple si uniscono in un sistema cellulare. Nelle aree densamente popolate si necessitano microcelle8tipicamente dal raggio di un centinaio di metri) e più base station vicine fra loro per servire un gran numero d'utenti.
- Cos'è l'handover o handoff: passaggio della connessione da una cella ad un'altra,tipicamente quando stiamo parlando al cell. e ci muoviamo,sconfinando dalla cella in cui è iniziata la conversazione. Permette che la connessione rimanga attiva altrimenti se fallisce,cade la linea.Ciò è specialmente vero nelle reti a commutazione di circuito dove si deve ristabilire al connessione prima di continuare.
- Cos'è il roaming: spostamento fra celle possedute da diversi operatori wireless. Tipicamente quando andate all'estero e vi compare sul cell. il nome dell'operatore straniero(Es. Swiss GSM,Orange,ecc..).
- Cos'è il QoS: grado di affidabilità di una rete. Individuata da 3 parametri:
- velocità: throughput e latenza;
- affidabilità;
- accuratezza: duplicazione o trasmissione errata di pacchetti. Vedere anche sul sito della cisco;
- Tecniche di multiplexing: tecnica per dividere un segnale fra più utenti. Questa condivisione dello spettro permette agli operatori wireless di massimizzare l'uso dei loro spettri per accomodare un gran numero d'utenti su canali minori.
- TDM: numerosi segnali sono combinati su un solo canale,ma ognuno di essi viene separato attraverso slot di tempo. I segmenti di tempo vengono assegnati ad un individuo e ruotati ad intervalli regolari,perchè tutti possano disporne. Il ricevente interpreta l'appropriato slot per riceve le informazioni. L'intervallo di tempo viene aggiornato continuamente per permettere un uso ottimale della larghezza di banda.
- FDM: anche qui numerosi segnali vengono combinati su un unico canale e a ciasuno di essi viene assegnata una frequenza per la comunicazione. Per comunicare chiamante e ricevente si sintonizzano sulla stessa frequenza(funzionamento simile alle stazioni radio).
- CDM: in questo caso ad ogni segnale viene affibiato un codice e li spedisce lungo tutto lo spettro. Ciò offre una grande efficienza nello sfruttamento dello spettro e abbassa molto il livello d'interferenza fra segnali. Un ricevente infatti accetterà solo i segnali con il codice appropriato.
Lezione di Martedì 18-10-05
- WAP: standard mondiale per la trasmissione e presentazione d'informazione via wireless a telefoni mobili e altri dispositivi wireless. La primaversione è stata realizzata nel '98 dal WAP Forum. Il WAP forum è stato fondato nel '97 da diverse grandi compagnie(come NOkia ed Ericsson) con l'intento di rendere le applicazioni internet wireless la corrente principale creando specifiche di sviluppo e framewrok per accelerarne lo sviluppo. Nel 2002 si è consolidato insieme ad altre istituzioni/compagnie nell'OMA,(sito).
- usa l'approccio pull(normali richieste del client al server) e la tecnica push,dove il contenuto viene spedito dal server al client tramite WTA(che permette di sfruttare le capacità telefoniche del dispositivo client tramite WML/WMLscript ed API).
- WAP può richiedere un gateway,a seconda della sua versione(detto anche WAP proxy) come intermediario fra client/server responsabile per:
- traduzione delle richieste da protocollo WAP ad HTTP-TCP/IP;
- codifica/decodifica dei contenuti in formati compatti adatti al dispositivo;
- implementa le funzioni di push tramite WTA viste prima;
Differenze fra WAP 1.x e WAP 2.x
WAP 1.x | WAP 2.x |
---|---|
fondato su protocolli propietari | stack di protocolli basato su quelli di internet |
usa WML/WMLscript | usa WML2,basato su XHTML |
richiede WAP proxy | non richiede WAP proxy,permette comunicazione diretta client/server anche se usarlo aggiunge dei servizi(location-based e push) |
WAP gap | il protocollo TLS elimina il WAP gap |
Stack del protocollo WAP
Le due versioni WAP hanno in comune il livello d'applicazione,sebbene con qualche diversità:
- WAE: corrisponde al livello d'applicazone secondo il modello OSI. Fornisce gli elementi necessari per l'interazione fra le applicazioni Web e il microbrowser del client:
- ha delle specifiche per il microbrowser sull'interpretazione del WML/WMLscript,così come il supporto per altri tipi di contentuo come le immagini bitmap wireless e altro ancora;nella versione WAP 2.x,si usa XHTML come linguaggio di markup,c'è un supporto per i folgi di stile,un sottoinsieme dei CSS orientato ai dispositivi mobili,mantiene la compatibilità con il WML 1.x,grazie a traformazioni XSLT.
WAP 1.x stack
- WSP: fornisce capacità simili all'HTTP/1.1 orientate per larghezza di banda bassa,per reti ad alta latenza,fornendo la possiblità di sospendere e riprendere le sessioni. La comunicazione fra il WAP proxy e il microbrowser avviene su questo livello;vale per le applicazioni basate sulle transazioni(accesso ai database);
- WTP: fornisce meccanismo affidabile di trasporto simile al TCP/IP eliminando il trattamento informativo addizionale delle informazioni sui pacchetti spediti fuori ordine e l'handshake a tre vie,per velocizzare il processo;vale per applicazioni basate su datagrammi(multimediali);
- WTLS: versione wireless del TLS,fornisce privacy,integrità dei dati,autenticazione client/server;
- WDP: servizio datagram che porta un'interfaccia comune alle portanti wireless(quindi è indipendente da essi). AL di sopra di bearer IP(GPRS/UMTS),c'è proprio UDP.
WAP 2.x stack
- WP-HTTP: profilo di HTTP per ambiente wirless,interoperabile con l'HTTP/1.1;
- TLS: profilo wireless di TLS,per transazioni sicure,eliminando il WAP gap;
- WP-TCP: profilo wireless di TCP,interoperabile con TCP,ma con meno overhead nei flussi di comunicazione;
- implementa servizi di:
- WAP push: invio di informazioni dal server al client attraverso un documento XML PAP ad un push proxy(PPG);
- UAprofile: permette ad un server di ottenere quante più informazioni possibili su un client,basato sulle specifiche CCPP.(vedi anche qui).
- EFI: permette alle applicazioni nel WAE di comunicare con applicazioni esterne,permettendo alle altre applicazioni di estendere le funzionalità delle applicazioni WAP,similmente a quanto fanno i plug-in per i browser;
- interfaccia di memorizzazione duratura: permette l'organizzazione,l'accesso e l'immagazzinamento dei dati;
- sincornizzazione dei dati: viene adottato SyncML,che fornisce un protocollo basato su XML per sincornizzare i dati attraverso WSP e HTTP;
- MMS;
Glossario
- WAP gap: nella versione WAP 1.x una connessione sicura in cui si usasse la crittografia per la trasmissione dei dati,aveva un anello debole: all'arrivo dei dati al gateway,a causa della diversità dei protocolli e del suo ruolo di traduttore,doveva decifrare i dati e convertirli nel formato cpmprensibile dall'altra parte della comunicazione,per poi ricrittarli. Per aggiungere sicurezza si può far si che questo processo avvenga dietro un firewall.
Lezione di Venerdì 21-10-05 SOSPESA
Lezione di Martedì 25-10-05
Architetture thin-client e smart-client
La scelta di quale architettura usare va pesata considerando vari fattori:
- utenti finali,loro competenze e bakground precedenti a cui sono abituati;
- tipo di dispositivo sul quale far girare le applicazioni,cosa permette e non;
- il tipo di connessione e in che modo si connette ai server delle imprese;
- fruibilità dei dati(solo sul server o se ne permette la gestione anche off-line);
- l'uso del servizio di notifica all'utente o meno;
- aspetti di sicurezza;
- l'autonomia del dispositivo(batteria);
Componenti dell'architettura thin-client
Il nome stesso richiama l'esiguità di software necessaria per quest'architettura:infatti serve solamente il microbrowser. Qui seguono nel dettaglio le componenti:
- microbrowser: usa URL per contattare il server Web. La sua risposta,contenente i linguaggio di markup,viene poi interpretata e visualizzata dal browser stesso. Se il bearer non è IP-based,ci sarà il solito WAP proxy ad effettuare le conversioni protocollari;
- caching: senza connessione solitamente l'utente non può accedere alle applicazioni o ai dati. Tramite il caching si può accedere a del contenuto off-line,anche se solitamente inadeguato a completare delle transazioni;
- Wireless Web Server e wireless application server: sta in ascolto su porte appropriate e inoltra le risposte;spesso contiene specifici framework wireless che lo aiutano nella formattazione del contenuto wireless;Le richieste vengono accolte dal Web Server e girate al wireless application server,il quale eseguirà l'appropriata applicazione/azione in conseguenza alla logica della richiesta
- Back-end system: il server web tramite meccanismi vari,accederà ai dati/servizi necessari;
- il protocollo principale è il WAP;
Pro e contro
Pro | Contro |
---|---|
sviluppo software minimale o nullo,si cura solo il lato server | richiede la connessione wireless per l'accesso ai dati(ad eccezione del caching dei browser); |
estende il modello di Internet | l'UI è semplice,minimale,con capacità limitate per contenuti grafici; |
UI familiari | l'eterogeneità vasta dei microbrowser rende la fase di testing delle applicazioni difficile |
disponibilità dei dati aggiornati | performance ridotta per via della latenza e al throughput di rete; |
sicurezza:nessun dato,importante o meno,viene memorizzato sul dispositivo client,ma resta tutto sul server |
se il server è down,i dati non sono più accessibili; |
"" | problemi di sicurezza:WAP gap |
"" | alti costi dovuti al tempo di connessione nelle reti circuit-switched |
Architettura smart-client
- si utilizzano applicazioni customizzate;
- permette la memorizzazione di dati sul dispositivo;
- non necessitano di connettività per poter essere eseguite e lavorare sui dati;
- L'integrazione con i dati dell'impresa avviene attraverso un processo di sincronizzazione;
- possiedono dei sistemi oeprativi in grado di far girare le applicazioni,usando librerie native all'OS o java;
- vi rientrano PDA,smart-phones,laptops,tabelt-pc,pocket pc;
Componenti dell'architettura smart-client
- smart-client: un eseguibile o un'applicazione java,che provvede ad incorporare i dati per memorizzarli;
- server di sincronizzazione: i dati vengono spediti al server di sincronizzazione,gestisce le comunicazioni con i database aziendali;
- database: vi accede il server di sincronizzazione attraverso svariati meccanismi
Pro e contro
Pro | Contro |
---|---|
i dati sono sempre disponibili ,anche senza copertura wireless. Al massimo verranno sincronizzati più tardi |
richiede un'integrazione con le funzionalità d'impresa |
Interfaccia sofisticata | sviluppo complesso delle applicazioni |
Performance elevate,per capacità di calcolo del dispositivo | "" |
disponibilità dei dati aggiornati | complessità di sviluppo nella programmazione attraverso le API native del dispositivo(curva d'apprendimento elevata per diversi dispositivi). Java aiuta tramite la sua portabilità a semplificare le cose |
La tariffazione avviene per dati scambiati su retu packed-switched | richiede cicli di sviluppo separati,aumentando il costo dello sviluppo stesso |
Sicurezza gestita in entrambe le parti e non delegata ad un gateway |
si aprono le porte al mondo dei virus |
Architettura a messaggi
Tre categorie principali:
- messaggistica utente-utente: si può usare l'e-mail,paging,SMS,IM,EMS,MMS. Il software è messo già a disposizione nel dispositivo e lo sviluppo richiede cura per la maggior parte,solo del lato server;
- notifiche e allerte: pushing di informazioni urgenti(di solito un URL che permette di raggiungere l'informazione necessaria. Le tecnologie usate sono il WAP push e l'HDML. Qui il software è parte del microbrowser;lo sviluppo richiede cura per la maggior parte,solo del lato server;
- messaggi fra applicazioni stesse: non si necessita dell'interazione con l'utente,server e client comunicano automaticamente,utile nelle sincronizzazioni con il server. Qui si richiede lo sviluppo di software che capisca il flusso di comunicazione fra client e server
Componenti dell'architettura di messaggi applicazione-applicazione
- Messaging client: usa la tecnica di store-and-forward dei messaggi(quando c'è la disponibilità di una connessione li spedisce sennò mette i messaggi in coda);
- Messaging server: comunica con il client,il suo nome è MOM(Message Oriented Middleware),molti dei quali sono basati su JMS(Java Message Service). Usa anch'esso la comunicazione asincrona: non appena il client si connette,il server spedisce i messaggi che ha in coda per quel dispositivo;
- Sorgenti di dati: comprendono databases,altre applicazioni o sistemi di messaggistica con cui si interrelaziona il server;
Vantaggi | Svantaggi |
---|---|
funzionalità di push messaging | aggiunge complessità allo sviluppo dell'applicazione |
tecnica asincrona di trasmissione store-and-forward | lo sviluppo deve essere curato sia lato client sia server |
ricezione personalizzata dei dati(scheduling della consegna) | incorporare funzionalità di messaging in un'applicazione richiede sviluppo addizionale e testing; |
opera sia su reti wireless sia wired | "" |
Processazione di una richiesta wireless
- stabilimento di una sessione wireless(se non già connesso o always on);
- sottoposizione di una richiesta,attraverso il browser del client. Il server carpisce da essa informazioni varie: URL richiesto,tipo di dispositivo e browser,richiesta POST/GET. SOlitamente le informazioni vengono codificate in formato binario per risparmiare banda,inviate alla base station e poi al gateway,se necessario;;
- Traduzione richiesta,da parte del gateway se necessario,convertendo il formato da binario ad ASCII,traducendo dal protocollo WAP all'HTTP da spedire su una rete IP-based(WAP gap);
- la richiesta viene accolta dal WAS ed accede ad altre applicazioni/database attraverso servlet/JSP,ASP,PHP o altre interfacce.
- si identifica il client wireless(tipo dispositivo /browser,immagini supportate,linguaggio preferito,ecc).In base a ciò ci si assicura della fruibilità del contentuto da parte del client,formattandolo per le sue capacità;
- processazione della richiesta,una volta che l'utente si è autenticato. Se è una risorsa statica verrà ritornata al gateway,se richiede contenuto dinamico,si possono personalizzare i dati basandosi sulle informazioni a disposizione dell'utente. ,accedendo alle sorgenti di dati.
- trasformazione del contenuto per il dispositivo(cambiare il linguaggio di markup,tipo di immagini,spesso si usa XML come formato base poi traformato attraverso fogli di stile XSLT per specifici browser e dispositivi);
- ritorno del contenuto al client,una volta appropriatamente formattato;
Lezione di Venerdì 28-10-05
Meccanismi di richiesta dati da client a server,e sua risposta tramite due metodi principali:
- Uso di CGI e simili: viene eseguito un processo separato per : ogni richiesta, l'output del programma viene rispedito in rete al client; N.B.:CGI non è nè un protocollo di comunicazione nè tanto meno un linguaggio, ma un sistema per definire delle variabili d'ambiente utilizzate dai processi; posso utilizzare i linguaggi che voglio, fra i più utilizzati troviamo perl;
- Uso di server API: si usano librerie dinamiche linkate al codice del server ed eseguito come un tutt'uno. Abbiamo vere e proprie applicazioni client e server. Il server non è iterativo ma multiconcorrente, più thread (processi leggeri) vengono lanciati per ogni richiesta;
- Abbiamo visto cosa sono:
- Java Servlet: sono qualcosa di simile alle applet ma eseguite server-side;
- JSP (Java Server Page): le richieste di questi file producono la loro compilazione in una servlet; vedi forum della sun per chiarimenti;
- PHP 5.0.5: può essere usato per:
- Server-side scripting
- scripting a linea di comando
- applicazioni grafiche client-side
Tutorial su Java Servlet e JSP:
- Tutorial della Sun
- Apache:
- Sito principale: qui
- Guida su Apache: HTML.it
- Installazione modulo PHP su Apache: qui (anche se consiglio di leggersi le istruzioni di installazione nel file zip);
- Tomcat,modulo per Apache: http://tomcat.apache.org/
- Guida ad IIS: qui
Tutorial per PHP:
- Home page
- risorse varie: qui
- PHP Absolute beginners
- Guida PHP sul sito ufficiale
- Alcuni scripts
- Altre guide;
- Programming links tutorial: http://apps.sholay.com/cgi-bin/jobs/tutoprog.html
Lezione di Venerdì 4-11-05
Introduzione all'XML
- Tutorial:
- XML e Apache: http://xml.apache.org/
Lezione di Martedì 8-11-05
Linguaggi di markup
WAP,WML Tutorial:
- http://www.w3schools.com/wap/
- http://wapitalia.html.it/wml/
- http://www.wirelessdevnet.com/channels/wap/training/wml.html
- http://xml.coverpages.org/wap-wml.html
- http://www.zvon.org/xxl/WMLTutorial/Output/introduction.html
- http://www.wmlscript.it/j2me/index.asp
XHTML,riferimenti:
- http://www.html.it/xhtml/
- http://www.w3schools.com/xhtml/
- http://www.zvon.org/xxl/xhtmlReference/Output/
- http://www.digitalmediaminute.com/reference/entity/index.php
- http://www.xhtml.org/
XHTML-MP:
- xhtml-mp_style_guide
- http://www.developershome.com/wap/xhtmlmp/
- http://www.xml.com/pub/a/2004/04/14/mobile.html
- tag list
HTML:
- Validator Service: qui
- http://www.w3schools.com/html/html_intro.asp
- http://www.cwru.edu/help/introHTML/toc.html
- http://www.html.it/guida/
VoiceXML:
SVG:
- http://www.html.it/svg/
- http://www.svg-whiz.com/wiki/index.php?title=Main_Page
- http://www.dmi.unict.it/~snicotra/svgweb/
- http://www.w3schools.com/svg/default.asp
- .SWF Vs SVG
Lezione di Venerdì 11-11-05
Tutorial: http://www.w3schools.com/xsl/
- http://www.zvon.org/xxl/XSLTreference/Output/
- http://www.zvon.org/xxl/XSLTutorial/Books/Book1/
- http://www.xml.com/pub/a/2000/08/holman/
- Risorse varie
- http://www.html.it/xslt/
- http://www.topxml.com/xsl/tutorials/intro/default.asp
- http://www.topxml.com/xsl/XSLTRef.asp
Tutorials:
- http://www.w3schools.com/xpath/default.asp
- http://www.zvon.org/xxl/XPathTutorial/General/examples.html
- http://www.html.it/linguaggi_xml/xml_02.htm
- Risorse varie
- Applicare trasformazioni XSLT con PHP
Lezione di Martedì 15-11-05
Generazione dinamica con XSLT - Esercitazione
Lezione di Venerdì 18-11-05
J2ME - Prima parte
- J2ME
- Documentazione
- http://www.wmlscript.it/j2me/index.asp (Tutorial)
- Introduction to Java wireless programming (PDF)
- Ricapitolazione argomenti trattati nelle lezioni di teoria
- Sun Java Wireless Toolkit
- Tutorials della Sun
- Developing Wireless Applications (PDF)
- J2ME Device list
- Build a smart J2ME mobile application- part I (accessibile previa registrazione)
- Build a smart J2ME mobile application- part II (accessibile previa registrazione)
- J2ME Polish (suite of tools for creating "polished" J2ME applications)
- Network programming with J2ME
- Javapedia
- http://www.javastaff.com/
- microjava.com
Lezione di Martedì 22-11-05
J2ME - Seconda parte
- MIDP specification
- Guida MIDP 2.0
- Java 2 Micro Edition from wikipedia (EN)
- Java 2 Micro Edition Programming from wikibooks (EN)
Lezione di Venerdì 25-11-05
Intervento Microsoft sulla programmazione per il .Net Compact Framework.
Sono online le slides in formato powerpoint.
Lezione di Martedì 29-11-05
Sono applicazioni che si avvantaggiano dell'informazione spaziale per fornire un servizio tempestivo,usate per:
- trovare un luogo d'interesse;
- avere informazioni dettagliate su come raggiungere un luogo;
- informazioni sul luogo in cui si trova l'utente;
- traffico e congestione delle strade;
- tracking delle merci;
- localizzazione automatica del veicolo;
- mapping delle strade;
- informazioni meteorologiche;
- servizi di pronto soccorso;
- notifiche in relazione ad un luogo preciso;
Si dividono in tre generazioni:
- generazione: serve un input manuale dell'utente di informazioni di localizzazione(CAP,nome di una città,indirizzo,ecc). In base ad esse l'applicazione provvede a fornire contenuto personalizzato;
- generazione: determinano informazioni di localizzazione autonomamente senza coinvolgere l'utente. Offrono servizi simili e hanno un accuratezza simile alle applicazioni di prima generazione(un raggio di 2/3Km);
- generazione: ottengono informazioni di localizzazione più accurate e possono autonomamente far partire dei servizi in base al contesto. Forniscono aggiornamenti istantanei su vari servizi)mapping delle strade,direzioni,tracking,ecc). Si discute di problemi legati alla privacy.
Tecniche di localizzazione dei dispositivi
Hanno come obiettivo quello di localizzare un dispositivo mobile e convertire il luogo in delle coordinate.
- soluzioni network-based: sono meno costose dell'alternativa anche se la loro precisione varia da alcune centinaia di metri a svariati chilometri a seconda della soluzione scelta. Si sfruttano delle base station,ognuna delle quali contiene un equipaggiamento per l'intercettazione radio che può riceve un segnale da un telefono attivo per esempio. Si può determinare la localizzazione del dispositivo prendendo in considerazione i segnali di una o più base stations. Più base stations sono coinvolte,più sarà accurata l'informazione di localizzazione;
- Cell-identity: è la tecnica più semplice ed economica. Si determina quale cella di una rete wireless il dispositivo sta usando e si comunica la sua localizzazione. Ha come svantaggio che non si può conoscere con certezza la posizione dell'utente all'interno della cella stessa. Il margine d'errore si aggira all'intorno a 1-2Km.
La situazione può migliorare se si considerano le microcelle invece della cella nella sua globalità.
Una ancora migliore soluzione è l'uso del timing advance(TA):si misura il tempo che impiega il segnale partito da un dispositivo mobile a raggiungere la base station. Questo permette di restingere il raggio di individuazione del dispositivo all'interno della cella.Solitamente vengono sviluppate applicazioni che comunicano con l'MPC(Mobile Positioning Center),per carpire le informazioni TA con la tecnica di cell-identity(e si parla di CGI-TA ovvero Cell Global Identity Timing Advance). Poichè in città ci sono più base station l'accuratezza è migliore i nquesti luoghi rispetto a quelli rurali. - Time Of Arrival(TOA): invece di usare una sola base station per localizzare il dispositivo,si usano le informazioni raccolte da 3 o più base station. Il segnale mandato dal dispositivo viene raccolto da tutte le base station in questione e tramine timing advance si calcolano i tempi di ricezione dei segnali(T1,T2,T3,...Tn).Viene richiesta una sincronizzazione fra le stazioni(usano un sistema GPS o un orologio atomico,entrambe soluzioni costose) ed accuratezza nelle misurazioni. Quindi è possibile effettuare una triangolazione delle coordinate attraverso intersezioni concentriche dei segnali ricevuti. Ha un margine d'errore che spazia dai 50m nelle aree urbane ai 150m nelle campagne.
- Angle Of Arrival(AOA): simile al TOA ma invece del tempo si sfrutta l'angolo con cui un segnale arriva alla stazione. Confrontando l'AOA fra più base stations(almeno 3)si può triangolare la posizione relativa di un dispositivo. Talvolta si usano entrambi AOA e TOA per una maggiore precisione. Tutto ciò sfrutta il teorema dei seni;
- Cell-identity: è la tecnica più semplice ed economica. Si determina quale cella di una rete wireless il dispositivo sta usando e si comunica la sua localizzazione. Ha come svantaggio che non si può conoscere con certezza la posizione dell'utente all'interno della cella stessa. Il margine d'errore si aggira all'intorno a 1-2Km.
- soluzioni Handset-based: sono più costose delle network-based ma hanno una precisione maggiore: è possibile localizzare un dispositivo con un margine di errore di alcuni metri dal dispositivo;
- E-OTD: simile al TOA ma la misurazione del tempo di arrivo viene eseguita da degli handset. Si misura il tempo di arrivo dei segnali dalla base station a due punti:il dispositivo mobile e la LMU(Local Measuring Unit),un luogo fissato. Servono almeno 3 base station per un'accurata triangolazione. Le base station devono mandare al dispositivo un tempo molto preciso,tutti i segnali spediti da esse devono essere spediti contemporaneamente,per considerare meglio il possibile movimento del dispositivo. LMU provvede un'accurata sorgente di misurazione dei tempi. Una volta calcolati i tempi l'handset registra le differenze di tempo dalle base stations. Dopo di che le distanze del dispositivo dalle stazioni possono essere calcolate comparando le differenze di tempo dalle misurazioni precedentemente effettuate. Le differenze di tempo possono essere convertite in una distanza poichè la velocità dei segnali è costante. La locazione relativa può essere calcolata in riferimento alla rete o all'handset. Le misurazioni avvengono attraverso software sopra a dell'hardware per i calcoli. Dalla posizione relativa si ottiene quella assoluta poichè conosciamo le posizioni delle base stations.
La precisione dell'E-OTD ha un margine d'errore fra i 50-100m - GPS: tecnologia di localizzazione più popolare utilizzata oggi. Usa 24 satelliti in orbita terrestre che mandano segnali a ricevitori GPS. I ricevitori possono comunicare con 3/4 satelliti contemporaneamente. L'unico svantaggio è che necessita di una linea di vista diretta con il satellite,rendendolo inutilizzabile all'interno di edifici per esempio. Una volta che il ricevitore ha ricevuto le misurazioni di posizionamento,può o calcolare direttamente nel dispositivo stesso le coordinate(richiedendo per questa soluzione hardware appropriato,facendone aumentare il costo) o demandare il calcolo ad un server di rete. Eventualmente si può connettere via Bluetooth(per es.)il ricevitore ad un dispositivo mobile per i calcoli,per non integrare l'hardware nel dispositivo stesso,risparmiando energia sulla batteria.
Funzionamento: i satelliti inviano costantemente segnali ai ricevitori GPS. Quest'ultimi calcolano quanto tempo ci mettono (almeno)3 segnali da 3 differenti satelliti ad essere ricevuti. Conoscendo la velocità del segnale,il ricevitore calcola la distanza dal satellite. E' importante la precisione assoluta,per evitare errori chilometrici,quindi a bordo dei satelliti ci sono orologi atomici a garantirla. Dopo di che si eseguono calcoli di triangolazione per calcolare le coordinate assolute. il GPS fornisce un margine d'errore dai 5m ai 40m,e può fornire informazioni tridimensionali date da latitudine,lingitudine ed elevazione.
A causa del bisogno della linea diretta di vista fra ricevitore e satellite,si può accompagnare questa tecnologia con una network based come backup in caso il GPS non possa essere usato. Un altro punto a sfavore è il tempo richiesto per ottenere i risultati(20/40 secondi).
Una soluzione è il A-GPS(o network-assisted GPS): si usano handset modificati che ricevono i segnali dai satelliti e li mandano ad un server di rete. Il server usa l'A-GPS per la misurazione dei dati. Quindi raccolgono regolarmente dati forniti dai satelliti fornendoli agli handset,svincolandoli dal peso di decodificare i messaggi satellitari attuali ma permettendogli di fare subito le misurazioni temporali,permettendo di fornire le informazioni di localizzazione in soli 1/8 secondi. Le computazioni complesse vengono fatte sul server.
- E-OTD: simile al TOA ma la misurazione del tempo di arrivo viene eseguita da degli handset. Si misura il tempo di arrivo dei segnali dalla base station a due punti:il dispositivo mobile e la LMU(Local Measuring Unit),un luogo fissato. Servono almeno 3 base station per un'accurata triangolazione. Le base station devono mandare al dispositivo un tempo molto preciso,tutti i segnali spediti da esse devono essere spediti contemporaneamente,per considerare meglio il possibile movimento del dispositivo. LMU provvede un'accurata sorgente di misurazione dei tempi. Una volta calcolati i tempi l'handset registra le differenze di tempo dalle base stations. Dopo di che le distanze del dispositivo dalle stazioni possono essere calcolate comparando le differenze di tempo dalle misurazioni precedentemente effettuate. Le differenze di tempo possono essere convertite in una distanza poichè la velocità dei segnali è costante. La locazione relativa può essere calcolata in riferimento alla rete o all'handset. Le misurazioni avvengono attraverso software sopra a dell'hardware per i calcoli. Dalla posizione relativa si ottiene quella assoluta poichè conosciamo le posizioni delle base stations.
Lezione di Venerdì 2-12-05
- ccpp: recommendation del W3C
Lezione di Martedì 6-12-05 SOSPESA
Lezione di Venerdì 9-12-05 SOSPESA
Lezione di Martedì 13-12-05
- Architettura CARE
Lezione di Venerdì 16-12-05
- Cocoon5bBZBb <a href="http://vofmlkqilvgc.com/">vofmlkqilvgc</a>, [url=http://qgaaohvpoomj.com/]qgaaohvpoomj[/url], [link=http://xbtrzrgjbkgi.com/]xbtrzrgjbkgi[/link], http://ggzwisgwxiqx.com/