Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-05-2012, 19:40   #1
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
[ANDROID-JAVA-PHP-MYSQL] problema connessione

Ciao a tutti ragazzi!! ho il seguente problema: sto implementando un'applicazione per android che si connette ad un db MySql (presente su un server virtuale wamp) sfruttando il linguaggio side-Server PHP. Se utilizzo l'emulatore di Eclipse funziona tutto bene ma se collego lo smartphone tramite usb e lo utilizzo come emulatore della mia applicazione, ecco che ho problemi di connessione col DB. Come mai ?
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 19:48   #2
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Non è ben chiaro come avviene la comunicazione. PHP come c'entra?

Hai creato un'app che si connette, via socket, al dbms o l'app si connette ad un webservice in php che, a sua volta, si connette al dbms?
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 19:50   #3
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
Quote:
Originariamente inviato da pabloski Guarda i messaggi
Non è ben chiaro come avviene la comunicazione. PHP come c'entra?

Hai creato un'app che si connette, via socket, al dbms o l'app si connette ad un webservice in php che, a sua volta, si connette al dbms?
la seconda che hai detto .. sono i file php che interrogano il DB mysql
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 19:52   #4
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da Tony Hak Guarda i messaggi
la seconda che hai detto .. sono i file php che interrogano il DB mysql
E come vengono chiamati questi script php?
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 19:57   #5
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
Quote:
Originariamente inviato da pabloski Guarda i messaggi
E come vengono chiamati questi script php?
Codice:
InputStream is = null;
		 ArrayList<NameValuePair> querySend = new ArrayList<NameValuePair>();

		  //the query to send



	querySend.add(new BasicNameValuePair("querySend",query));
	querySend.add(new BasicNameValuePair("pivacf",pivacf));

	  //http post
	  try{
	    HttpClient httpclient = new DefaultHttpClient();
	    HttpPost httppost = new HttpPost("http://10.0.2.2//Android/indexPag.php");
	    httppost.setEntity(new UrlEncodedFormEntity(querySend));
	    HttpResponse response = httpclient.execute(httppost);
	    HttpEntity entity = response.getEntity();
	    is = entity.getContent();
	  }catch(Exception e){
	    Log.e("log_tag", "Error in http connection "+e.toString());
	  }
in questo modo creo la connessione con il file php e gli invio l'eventuale query
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 20:06   #6
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Una normale POST quindi.

A questo punto o il firewall sul tuo pc blocca l'accesso dal telefono o 10.0.2.2 non è l'ip giusto ( ma non credo ).

Potrebbe pure essere che il telefono impedisce all'applicazione di inviare pacchetti tcp ( ma lo ritengo poco probabile visto che sei in modalità debug ).
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 20:11   #7
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
Quote:
Originariamente inviato da pabloski Guarda i messaggi
Una normale POST quindi.

A questo punto o il firewall sul tuo pc blocca l'accesso dal telefono o 10.0.2.2 non è l'ip giusto ( ma non credo ).

Potrebbe pure essere che il telefono impedisce all'applicazione di inviare pacchetti tcp ( ma lo ritengo poco probabile visto che sei in modalità debug ).
ecco bravo ! un post ! ma è corretto programmare in questo modo ? sai com'e' .. sto facendo un tirocinio in azienda e non sono molto seguito ..e quindi ho visto tante cose da google ! grazie
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 20:15   #8
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da Tony Hak Guarda i messaggi
ecco bravo ! un post ! ma è corretto programmare in questo modo ? sai com'e' .. sto facendo un tirocinio in azienda e non sono molto seguito ..e quindi ho visto tante cose da google ! grazie
Tutto ciò che funziona è corretto. Se poi vuoi sapere se è il modo più elegante, la risposta è dipende.

Un'app che si connette direttamente al dbms necessita che il dbms sia in ascolto su tutte le interfacce di rete ( e non solo la loopback ), il che genera possibili problemi di sicurezza. D'altro canto, dover intermezzare con degli script php potrebbe essere vista come una soluzione poco elegante.

Però se i colossi dell'IT usano interfacciare i loro dbms tramite servlets et similia, non vedo perchè non lo possa fare tu. Così facendo il servizio server-side diventa indipendente da qualsiasi client, usa un'api standard per comunicare con i client e può essere riciclato in tanti altri progetti.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 20:25   #9
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
infatti ho pensato di rendere il client il piu' indipendente possibile e far assumere le responsabilita' solo al server ..e poi php si interfaccia benissimo con mysql .. mi sto trovando molto bene per come sto implementando il tutto .. tornando al problema iniziale non so se le cause che mi hai proposto possano essere quelle. Con l'emulatore va tutto ok .. quando collego lo smartphone tramite usb e inserisco username e password nella mia schermata dell'applicazione e quindi vado a verificare se l'utente è registrato per poter utilizzare l'applicativo, mi compare l'alert (creato sempre da me) : utente non registrato... mi sembra tutto cosi' strano ....
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 21:35   #10
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Controlla cose viene effettivamente passato nella variabile $_POST.

Il sospetto è che android possa fare qualche tipo di preprocessing prima di inviare il form ( tipo convertire in utf-8 e cose simili ) e quindi lo script php si confonde.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 21:50   #11
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
Quote:
Originariamente inviato da pabloski Guarda i messaggi
Controlla cose viene effettivamente passato nella variabile $_POST.

Il sospetto è che android possa fare qualche tipo di preprocessing prima di inviare il form ( tipo convertire in utf-8 e cose simili ) e quindi lo script php si confonde.
questo è il codice che uso per inviare dati (ad es. stringhe che rappresentano le query sql):

Codice:
 try{
		    BufferedReader reader = new BufferedReader(
		               new InputStreamReader(is,"iso-8859-1"),8);
		    StringBuilder sb = new StringBuilder();
		    String line = null;
		      while ((line = reader.readLine()) != null) {
		        sb.append(line + "\n");
		      }
		    is.close();
		   result=sb.toString();
		   result = result.trim();			
			String temp = result.substring(result.length()-4,result.length());
			if (!(temp.equals("null"))){
				
		    try {
		         JSONArray jsonArray = new JSONArray(result);

		         if (arrayString != null){
		         for (int i = 0 ; i < arrayString.length;i++){
		            JSONObject jsonObject = jsonArray.getJSONObject(0);
		            
		            v.add(jsonArray.getJSONObject(0).getString(arrayString[i]));}

		         }
		         
		    } catch (Exception e) {
		    
		         e.printStackTrace();
		      }		   
			}
			
		  }catch(Exception e){
		    Log.e("log_tag", "Error converting result: "+e.toString());
		  }
		  
		  Log.i("SendQUERY", result);
		  return v;
		  }
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 22:08   #12
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
E il login? Come avviene? Se compare l'alert che dice utente non registrato, può essere un problema di login. Il cookie usato per tracciare la sessione viene trasmesso?
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 22:11   #13
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
il codice php ce l'ho in ufficio domani te lo posto ..per la seconda domanda..ehm.. che intendi ? scusa l'ignoranza

ps cmq è una semplice select ..e il file php invia un jsonarray che viene tradotto in una listalinkata dal file java che contiene i risultati(ho fatto na genialata insomma XD )
__________________

Ultima modifica di Tony Hak : 22-05-2012 alle 22:13.
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 22:21   #14
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da Tony Hak Guarda i messaggi
..per la seconda domanda..ehm.. che intendi ? scusa l'ignoranza
Siccome hai detto che visualizza quell'alert, suppongo ci sia un qualche sistema di login che permette solo a chi è loggato di inviare le query.

Comparendoti quell'alert, è logico pensare che il problema sia nella procedura di login. Difficile dire perchè sull'emulatore funziona e sul device reale no.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 22:31   #15
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
Quote:
Originariamente inviato da pabloski Guarda i messaggi
Siccome hai detto che visualizza quell'alert, suppongo ci sia un qualche sistema di login che permette solo a chi è loggato di inviare le query.

Comparendoti quell'alert, è logico pensare che il problema sia nella procedura di login. Difficile dire perchè sull'emulatore funziona e sul device reale no.
l'utente inserisce nome ut. e pass. sulla prima schermata dell'app .. preme "entra" ..il codice associato all'azione consiste nell'inviare una stringa rappresentante la query di select al file php. Questa viene letta ed eseguita e i risultati vengono messi in un jsonarray e inviati di nuovo a java che li traduce sottoforma di una lista linkata per meglio gestirli.. un semplice if controlla se nella lista linkata sono presenti il nome utente e la password e di conseguenza si passa (o viene visualizzato l'alert "nome utente non trovato") alla seconda schermata .. forse cosi' si riesce a capire meglio..scusa se ho detto ogni singolo passo..cosi' sono piu' chiaro
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 22:47   #16
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
In questo caso puoi pure controllare che l'array json restituito sia effettivamente quello che ci si aspettava.

Se non lo è o la query non ha funzionato o l'app ha inviato dati non corretti allo script.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2012, 22:49   #17
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
Quote:
Originariamente inviato da pabloski Guarda i messaggi
In questo caso puoi pure controllare che l'array json restituito sia effettivamente quello che ci si aspettava.

Se non lo è o la query non ha funzionato o l'app ha inviato dati non corretti allo script.
ok..domani in ufficio vedo di risolvere il problema ti faccio sapere ! grazie mille per la disponibilita' !
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 23-05-2012, 09:29   #18
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Tony Hak Guarda i messaggi
l'utente inserisce nome ut. e pass. sulla prima schermata dell'app .. preme "entra" ..il codice associato all'azione consiste nell'inviare una stringa rappresentante la query di select al file php.
Eh? Vorresti dire che passi al php qualcosa come: select * from users where username='' and password=''?


Quote:
Questa viene letta ed eseguita e i risultati vengono messi in un jsonarray e inviati di nuovo a java che li traduce sottoforma di una lista linkata per meglio gestirli..
Dato che le App sono pubbliche significa che il tuo database è aperto al pubblico... E chiunque può eseguire qualunque query sul tuo database...

Quote:
un semplice if controlla se nella lista linkata sono presenti il nome utente e la password e di conseguenza si passa (o viene visualizzato l'alert "nome utente non trovato") alla seconda schermata .. forse cosi' si riesce a capire meglio..scusa se ho detto ogni singolo passo..cosi' sono piu' chiaro
Stai facendo l'autenticazione lato client e non lato server...

Secondo me devi rivedere il disegno del tuo sistema nel complesso.
La parte php deve richiedere una qualche forma di autenticazione ed esporre solo metodi specifici, non un generico "ExecuteQuery".
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 23-05-2012, 09:51   #19
Tony Hak
Senior Member
 
L'Avatar di Tony Hak
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 1661
buongiorno! sono in ufficio e ti incollo il log dell'errore

05-23 09:48:57.259: E/log_tag(5457): Error in http connection org.apache.http.conn.HttpHostConnectException: Connection to http://10.0.2.2 refused
05-23 09:48:57.259: E/log_tag(5457): Error converting result: java.lang.NullPointerException


grazie per l'aiuto !
__________________
Tony Hak è offline   Rispondi citando il messaggio o parte di esso
Old 23-05-2012, 11:29   #20
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da Tony Hak Guarda i messaggi
buongiorno! sono in ufficio e ti incollo il log dell'errore

05-23 09:48:57.259: E/log_tag(5457): Error in http connection org.apache.http.conn.HttpHostConnectException: Connection to http://10.0.2.2 refused
05-23 09:48:57.259: E/log_tag(5457): Error converting result: java.lang.NullPointerException


grazie per l'aiuto !
beh mi pare chiaro, la connessione viene rifiutata

o è il firewall o c'è qualcosa che non va nella logica che gestisce l'autenticazione
pabloski è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
Volkswagen avvia la produzione su CEA: c...
La crisi delle memorie non influenzer&ag...
MoM-z14 è la galassia scoperta da...
Da Sony nuovi display professionali dell...
Com'è fatta una delle e-bike pi&u...
iPhone 16 domina il 2025: ecco la classi...
Huawei a supporto delle startup: potenzi...
Iliad è il miglior operatore di l...
Le pompe di calore parlano italiano: Bon...
Moltbot non è solo un chatbot: ag...
Sinner e Alcaraz fermati dall'arbitro: i...
L'audio-video professionale arriva a MIR...
Musk fa i complimenti alla Cina: nel set...
Agcom ha avviato verifiche sul format 'F...
Bose QuietComfort Ultra (2ª Gen) a meno ...
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: 18:41.


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