Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-11-2012, 15:10   #1
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
JAVA/TomCat: trasformarlo in un server non http

Salve a tutti, ho bisogno di programmare un server e vorrei che esso interagisca col client interamente via XML, senza quindi passare dal protocollo HTTP.

Avevo pensato perciò a tomcat, ho fatto la servlet e l'ho posizionata su localhost, in modo tale che sia accessibile dalla radice.

Però mi sto accorgendo che non riesco a gestire le richieste e le risposte prescidendo dall'http, visto che a quanto pare anche la classe GenericServlet, che mi sembrava l'ideale per questo lavoro, lo utilizza.

Qualcuno sa per caso cosa fare a questo punto? Vorrei un tipo di comunicazione di questo tipo:

Codice:
// richiedi l'autenticazione ed un session id
<query type="100" user="utente1" password="secret" />
// risponde dicendo che l'utente è autorizzato e gli da un session id
<response type="101">3223hbbv342uy1jjj1</response>
// richiedi dei dati generici
<query type="###" />
e via dicendo..

Mi consigliate qualcosa?
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2012, 15:22   #2
idoido
Senior Member
 
Iscritto dal: May 2008
Messaggi: 429
sinceramente ti consiglio di capire meglio cosa ti serve

http è un protocollo che trasporta dei dati, il contenuto lo decidi tu, a che pro modificare il modo in cui i dati vengono trasportati?
idoido è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2012, 15:44   #3
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
Quote:
Originariamente inviato da idoido Guarda i messaggi
sinceramente ti consiglio di capire meglio cosa ti serve

http è un protocollo che trasporta dei dati, il contenuto lo decidi tu, a che pro modificare il modo in cui i dati vengono trasportati?
Potrei farlo anche con HTTP, però sarebbe meglio un protocollo ad hoc. Le comuncazioni che dovrei fare sono caratterizzate da avere una quantità di dati inviati molto vicina alla quantità di dati ricevuti.

HTTP non è fatto per questo: certo potrei addattarmi e passare tutto via post, ma credo che troverei meno problemi nel sostituire HTTP con un un protocollo ad hoc, anche in termini di pesantezza: essendo un'applicazione per smartphone sarebbe più leggero nel modo in cui l'ho pensata.

Ovvio che se poi trovo troppi problemi faccio un passo indietro e poi torno sull'HTTP.

Ah, ho trovato anche questo che fa al caso mio, un framwork per java
http://mina.apache.org/mina-project/...art-guide.html
Apache Mina

sembrerebbe ottimo, ma se si può fare efficacemente anche con tomcat tanto meglio.
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2012, 16:07   #4
idoido
Senior Member
 
Iscritto dal: May 2008
Messaggi: 429
scusami, ma qui secondo me stiamo continuando a parlare del nulla.

l'overhead (e quindi la pesantezza) del protocollo http ti sembra troppa? stiamo parlando di bytes, poniamo che invii in http un file xml da 1MB, non sono certo gli header dello scambio http che ti rallentano il tutto.

poi parli di applicazioni per smartphone, puoi sempre utilizzare le socket (e quindi fai passare i dati come vuoi), poi quando avrai i primi problemi con firewall & co. capirai perché si usa http per scambiare dati tra un client e un server.
idoido è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2012, 20:04   #5
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
I pacchetti da scambiare sono piccoli e frequenti, quindi l'overhead peserebbe abbastastanza nella conversazione.
Inoltre un protocollo ad hoc mi sembrava molto elegante come soluzione ed in più minimizzerebbe la grandezza dei pacchetti.

Per il client utilizzerei ovviamente le socket, per il server invece non volevo scendere troppo di livello e quindi usare le socket perchè la questione multi threading avrebbe complicato le cose e reso il programma troppo instabile (visto che non sono poi così esperto, è la prima volta che uso java). Per questo ho pensato a tomcat, visto che ho letto che può gestire servlet non html, anche se non ho ancora trovato un esempio decente.

Fatto stà che se la questione si fa più complessa del previsto dovrei necessariamente lasciar perdere e tornare sull'http.

Pensi proprio che sia una pessima idea?
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2012, 21:58   #6
idoido
Senior Member
 
Iscritto dal: May 2008
Messaggi: 429
Quote:
Originariamente inviato da cicciopasticcio1 Guarda i messaggi
I pacchetti da scambiare sono piccoli e frequenti, quindi l'overhead peserebbe abbastastanza nella conversazione.
Inoltre un protocollo ad hoc mi sembrava molto elegante come soluzione ed in più minimizzerebbe la grandezza dei pacchetti.

Per il client utilizzerei ovviamente le socket, per il server invece non volevo scendere troppo di livello e quindi usare le socket perchè la questione multi threading avrebbe complicato le cose e reso il programma troppo instabile (visto che non sono poi così esperto, è la prima volta che uso java). Per questo ho pensato a tomcat, visto che ho letto che può gestire servlet non html, anche se non ho ancora trovato un esempio decente.

Fatto stà che se la questione si fa più complessa del previsto dovrei necessariamente lasciar perdere e tornare sull'http.

Pensi proprio che sia una pessima idea?
secondo me, almeno in questa fase di sviluppo dell'applicazione, è inutile.
concentrati nel far funzionare l'applicazione, e poi vedi i colli di bottiglia e le possibili ottimizzazioni, creare un protocollo o modificare un server (web o di altro tipo) mi sembra una esagerazione se non c'è una precisa motivazione dietro (e l'invio di pacchetti piccoli e frequenti non lo è)

ps: prova a guardare il protocollo XMPP, magari fa al caso tuo.
idoido è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2012, 09:40   #7
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
Capisco,
ma per il problema firewall non si potrebbe comunque parlare sulla porta 80 ma col protocollo che dico io? Non penso che il firewall se ne accorga !
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
Sembra ormai certo: la prossima Xbox sar...
“Solutions Beyond Displays”: la strategi...
La società europea The Exploratio...
Dalle auto ai robot umanoidi: Faraday Fu...
Vodafone annuncia la dismissione di un s...
Stiga lancia i nuovi robot tagliaerba co...
Bullismo e cyberbullismo, Keenetic lanci...
Con AI Skills Checker Bitdefender mette ...
E-bike giapponese con 1.000 km di autono...
Un eVTOL con cui basta saper andare in b...
Dal mercato cinese al mondo: HONOR firma...
Sovranità digitale: l'UE sperimen...
Accesso alla memoria su Windows 11 solo ...
iPhone 18 Pro Max con batteria da oltre ...
Windows 11, cali di prestazioni sulle GP...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 19:21.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v