Foros del Web » Programando para Internet » PHP »

Como conectar app movil (phonegap) con mysql remoto

Estas en el tema de Como conectar app movil (phonegap) con mysql remoto en el foro de PHP en Foros del Web. Hola a todos... Incursionando en el mundo de las aplicaciones moviles compilaas con Phonegap me encuentro con un escollo dificil de sortear... Estoy tratando de ...
  #1 (permalink)  
Antiguo 11/07/2012, 03:38
 
Fecha de Ingreso: febrero-2009
Ubicación: Cordoba, Argentina
Mensajes: 9
Antigüedad: 15 años, 9 meses
Puntos: 0
Pregunta Como conectar app movil (phonegap) con mysql remoto

Hola a todos...

Incursionando en el mundo de las aplicaciones moviles compilaas con Phonegap me encuentro con un escollo dificil de sortear...
Estoy tratando de levantar informacion de un servidor web (php+mysql) a traves de ajax...

Utilizo un ejemplo practico que luego, si funciona, trabajare en la adaptacion del mismo para mostrar los datos requeridos. De momento, trabajo con el ejemplo que detallo a continuacion, para aprender la manera de conectar.

La aplicacion es simple... y consta de solo 3 archivos en la app y uno en el servidor remoto.

Lado App (Movil)
index.html

Código:
<!DOCTYPE HTML>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no;" />

	<script src="js/jquery-1.7.2.min.js"></script>
    <script src="js/jquery.jsonp-2.2.0.min.js" type="text/javascript"></script>

	<script src="js/load-json.js"></script>
</head>
<body>
	<div id="output"></div>
</body>
</html>
js/jquery-1.7.2.min (No necesita descripcion no?)
ajax.js

Código:
$(document).ready(function(){
	$(document).bind('deviceready', function(){
		//Phonegap ready
		onDeviceReady();
	});

	var output = $('#output');

	$.ajax({
		url: 'http://www.nombredemiweb.com.ar/landmarks.php',
		dataType: 'jsonp',
		jsonp: 'jsoncallback',
		timeout: 5000,
		success: function(data, status){
			$.each(data, function(i,item){ 
				var landmark = '<h1>'+item.name+'</h1>'
				+ '<p>'+item.latitude+'<br>'
				+ item.longitude+'</p>';
			
				output.append(landmark);
			});
		},
error: function(err, textStatus, errorThrown) {
                 output.text("There was an error [" + textStatus + "] loading the data.");
                 console.log(err);
                 console.log(errorThrown);
              } 
	});
});
Lado Servidor:
landmarks.php

Código PHP:
<?php
header
('Content-type: application/json');
$server "localhost";
$username "usuario";
$password "clave";
$database "database";
$con mysql_connect($server$username$password) or die ("Could not connect: " mysql_error());
mysql_select_db($database$con);
$sql "SELECT id, l_name AS name, l_lat AS latitude, l_long AS longitude FROM landmarks ORDER BY l_name";
$result mysql_query($sql) or die ("Query error: " mysql_error());
$records = array();
while(
$row mysql_fetch_assoc($result)) {
    
$records[] = $row;
}
mysql_close($con);
echo 
$_GET['jsoncallback'] . '(' json_encode($records) . ');';
?>
El problema que encuentro es el siguiente. Al ejecutarlo en modo web digamos (llamando al index.html, tanto en localhost como en algun dominio, funciona perfecto, buscando la info en mysql, y mostrandola en el html, tal como se requiere. El problema, es que al ejecutarla en la aplicacion compilada (Instalada en Blackberry) sale el error There was an error [timeout] loading the data.
Alguien ha tenido el mismo problema? Podria orientarme hacia donde debo mirar para solucionarlo? (version de jQuery, version de PHP, codigo, permisos, etc)
Aclaro que el servidor existe, y si ejecuto directamente el php remoto obtengo:
Código:
([{"id":"1","name":"Big Ben","latitude":"51.500600000000","longitude":"-0.124610000000"},{"id":"4","name":"Hadrian's Wall","latitude":"55.024453000000","longitude":"2.142310000000"},{"id":"2","name":"Stonehenge","latitude":"51.178850000000","longitude":"-1.826446000000"},{"id":"3","name":"White Cliffs of Dover","latitude":"51.132020000000","longitude":"1.334070000000"}]);
Desde ya, agradecere cualquier orientacion que me puedan dar.

Saludos desde Argentina.
  #2 (permalink)  
Antiguo 11/07/2012, 06:58
Avatar de maycolalvarez
Colaborador
 
Fecha de Ingreso: julio-2008
Ubicación: Caracas
Mensajes: 12.120
Antigüedad: 16 años, 3 meses
Puntos: 1532
Respuesta: Como conectar app movil (phonegap) con mysql remoto

phonegap (cordova) es capaz de permitir conexiones ajax a servidores remotos, intenta usarlo sin JSONP, recuerda que la aplicación phonegap usa el navegador nativo, pero las peticiones son capturadas por el FW.

en casos como iOS y Blackberry se debe establecer una "lista blanca" para acceso a servidores externos: http://community.phonegap.com/nitobi..._externalhosts
__________________
¡Por favor!: usa el highlight para mostrar código
El que busca, encuentra...
  #3 (permalink)  
Antiguo 11/07/2012, 12:28
 
Fecha de Ingreso: febrero-2009
Ubicación: Cordoba, Argentina
Mensajes: 9
Antigüedad: 15 años, 9 meses
Puntos: 0
Respuesta: Como conectar app movil (phonegap) con mysql remoto

tengo declarado en config.xml lo siguiente:

Código:
<access uri="http://www.miweb.com.ar" subdomains="true">
Donde http://www.miweb.com.ar es el dominio donde esta el php que se comunica con mysql.
  #4 (permalink)  
Antiguo 01/08/2012, 18:23
 
Fecha de Ingreso: agosto-2012
Mensajes: 1
Antigüedad: 12 años, 3 meses
Puntos: 0
Respuesta: Como conectar app movil (phonegap) con mysql remoto

tu problema esta en que los datos que te envia el servidor estan en formato json y tines que mostrarlos en formato html usandolas funciones de jquery para poder mostrarlas en tu app..
puedes usar la funcion each() y con un while mostrar todos los datos...
pero en si tu cidgo fuente esta bien..

suerte espero te sirva

Etiquetas: ajax, mysql, phonegap
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 22:12.