Torna indietro   Hardware Upgrade Forum > Software > Programmazione

OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Abbiamo potuto mettere le mani in anteprima sul nuovo monitor MSI dedicato ai giocatori: un mostro che adotta un pannello QD-OLED da 26,5 pollici con risoluzione 2560 x 1440 pixel, frequenza di aggiornamento fino a 500 Hz e tempo di risposta di 0,03 ms GtG
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI aggiorna la sua linea di droni ultraleggeri con Neo 2, un quadricottero da 160 grammi che mantiene la compattezza del predecessore ma introduce una stabilizzazione meccanica a due assi, sensori omnidirezionali e un sistema LiDAR
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


OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone L'IA "seria" di Appian è divers...
Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
I social network hanno stancato gli ital...
Star Citizen supera i 900 milioni di dol...
Netflix ha eliminato la funzione Cast pe...
L'IA è una bolla e scoppier&agrav...
Un rapporto collega i data center di Ama...
Troppa concorrenza per Cherry (quella de...
Entro il 2035 la Cina vuole costruire de...
Tineco in super sconto: ultimo giorno di...
La Cina creerà una costellazione ...
I veicoli elettrici emettono radiazioni ...
Stai per acquistare una PS5? Attento al ...
iPhone 17 Pro Max finalmente disponibile...
Apple, Sony, Bose, Beats, Sennheiser, CM...
Arriva il Raspberry Pi 5 da 1 GB, ma por...
Draghi scuote l'Europa: 'rischio stagnaz...
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: 21:38.


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