Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo
Abbiamo provato per diversi giorni una new entry del mercato italiano, la Gowow Ori, una moto elettrica da off-road, omologata anche per la strada, che sfrutta una pendrive USB per cambiare radicalmente le sue prestazioni
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design
OnePlus 15 nasce per alzare l'asticella delle prestazioni e del gaming mobile. Ma non solo, visto che integra un display LTPO 1,5K a 165 Hz, OxygenOS 16 con funzioni AI integrate e un comparto foto con tre moduli da 50 MP al posteriore. La batteria da 7.300 mAh con SUPERVOOC 120 W e AIRVOOC 50 W è la ciliegina sulla torta per uno smartphone che promette di offrire un'esperienza d'uso senza alcun compromesso
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media
Vediamo come si comporta il Ryzen 5 7500X3D, nuovo processore di casa AMD che fonde 6 core Zen 4 con la tecnologia 3D V-Cache, particolarmente utile in scenari come il gaming. Annunciato a un prezzo di listino di 279€, il nuovo arrivato sarà in grado di diventare un riferimento per i sistemi budget? Ecco cosa ne pensiamo.
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


Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design   Recensione OnePlus 15: potenza da vendere e batt...
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media AMD Ryzen 5 7500X3D: la nuova CPU da gaming con ...
SONY BRAVIA 8 II e BRAVIA Theatre System 6: il cinema a casa in formato compatto SONY BRAVIA 8 II e BRAVIA Theatre System 6: il c...
KTC H27E6 a 300Hz e 1ms: come i rivali ma a metà prezzo KTC H27E6 a 300Hz e 1ms: come i rivali ma a met&...
Dacia Sandriders, incontro con piloti e ...
Quanto costerà la Steam Machine? ...
QNAP TS-h1655XeU-RP: filesystem ZFS e co...
Etica e software libero protagonisti a S...
Il reattore che ricarica le batterie sca...
AMD FSR Redstone: la nuova tecnologia ba...
Meta Quest 3S a un prezzo senza preceden...
Rischio per gli SSD? I driver chipset AM...
Quanto sono 'woke' le intelligenze artif...
Rockstar rilancia Red Dead Redemption su...
Blue Origin centra l'obiettivo: New Glen...
Regali di Natale spendendo poco con il B...
Windows 11/10: Microsoft chiude per semp...
Speciale CMF Nothing: smartphone, smartw...
Cooler Master presenta MasterFrame 400 M...
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: 17:40.


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