Pages

martes, agosto 07, 2012

JSONP - Cross Domain AJAX, Ejemplo con jQuery y PHP

Si ud. como yo, es un pobre programador que ha intentado hacer alguna aplicacion para telefonos Android y tuvo la peregrina idea de hacer que el telefono tenga la logica de su lado y se comunique via Ajax con su servidor... Entonces esta entrada se la dedico desde el fondo de mi corazón.

Después de mucho deambular leyendo un montón de incoherencias llegué a un post que me mostró la luz. http://bob.ippoli.to/archives/2005/12/05/remote-json-jsonp/
De ahí en mas avancé y aqui van mis conclusiones.

1) llamada ajax en javascript con jQuery:

$.ajax({
 dataType: "jsonp",
 url: "http://algunotrodominio.com/unscript.php",
 data: "parametro1=valor1&parametro2=valor2",
 type: GET,
 crossDomain: true,
 jsonpCallback:'jpCallback',
 success: function(jsondata) {   
  datos = jsondata[0].respuesta.datos;
  otros = jsondata[0].respuesta.otracosa;
  (hacer algo con todo esto.)
 },
 error: function (jqXHR, textStatus, errorThrown) {
   (haceralgo)
 }
});

jpCallback(jsondata){
  (pueden ejecutar alguna validación previa con los datos,
 o no hacer absolutamente nada.)
} 

2) unscript.php :
<?php

$json = '{ "respuesta": {
   "datos": [ 
              {"codigo": 1, "dato": "algo1"},
              {"codigo": 2, "dato": "algo2"}
            ],
   "otracosa":"undatomasadevolver"  
   }   
}';
  
echo 'jpCallback(['.$json.'])';
?> 

Y eso es todo. Si no lo captaron: al $.ajax() de jQuery modifican el dataType a "jsonp", esto solo ya habilita a hacer una llamada cross domain. pero hay un parametro mas crossDomain : true. Sin esto tambien funciona. jsonpCallback : 'nombredefuncioncallback' Al decir que esto es "jsonp" jQuery agrega 2 parametros a la cadena de datos que se envian por ejemplo:

http://algunotrodominio.com/unscript.php?callback=jQuery17206061169685839634_1344380380503&parametro1=valor1&parametro2=valor2&_=1344380387364

si en cambio agregamos el parametro jsonpCallback : 'funcioncallback' entonces la llamada se parecera a esto:

http://algunotrodominio.com/unscript.php?callback=funcioncallback&parametro1=valor1&parametro2=valor2&_=1344380387364

Como sea lo importante es que la devolucion del script PHP debe ser el nombre de la funcion callback y como parametro de la funcion el JSON que quiero devolver. jQuery ejecuta entonces la funcion callback y luego al success: envia solo el objeto JSON. En el ejemplo muestro como acceder a los distintos componentes.

Espero que les sea útil.

viernes, julio 27, 2012

FIREBIRD: Convertir un Unix timestamp, equivalente a MYSQL FROM_UNIXTIME()

En teoría los Unix timestamp, son los segundos transcurridos desde la medianoche del primero de enero de 1970, en MySQL hay dos funciones para manejar estos timestamps FROM_UNIXTIME() y UNIX_TIMESTAMP(). Ahora, dentro del mismo MySQL la conversión entre ambas funciones no es exacta, debido (segun entendí) a las diferencias locales según la zona horaria desde donde se trabaje... O sea, no pidan demasiada precisión muchachos que esto no es una ciencia exacta!!!.
Como sea el bueno de Firebird (la base de datos con la que habitualmente trabajo) no tienen contemplado esto asi que para obtener una fecha legible a partir de un Unix timestamp yo hice esto:

select dateadd(second, 1255033470, cast('01/01/1970 00:00:00.0000' as timestamp)) 
from rdb$database;

Por ahora sirve a mis propositos, si logro entender como hacer jugar los problemas de ubicación lo mejoro. Si alguien tiene alguna mejor idea soy todo ojos!.

viernes, junio 08, 2012

Mis Repositorios Imprescindibles de UBUNTU

Ultima versión del FFmpeg (Conversor de video)
Comando apt:
ppa:jon-severinsson/ffmpeg
__________________________________________________________________________

Este muchacho Adrian Mariuz Popa, mantiene un repositorio con las ultimas versiones de Firebird actualizadas y su respectivo php-interbase!!
Comando apt:
ppa:mapopa/ppa
__________________________________________________________________________

Un tema de iconos muy bueno Gartoon Redux
Comando apt:
ppa:tweenk/ppa
__________________________________________________________________________

Como Ubuntu da para todo existe un Ubutnu SE donde SE significa "Satanic Edition", que viene a ser una boludez con una estética particular, pero, estos pibes mantienen actualizado un tema de iconos que para mi es por lejos el mejor que existe: Buuf Icons, asi que a incluir el repositorio que se acaba el mundo. Están desactualizados, pero solo me interesa mantener actualizado el paquete de iconos buuf.
Comando apt:
deb http://ubuntusatanic.org/hell oneiric main
Secure Key: 
wget -q http://ubuntusatanic.org/ubuntu-se-key.gpg -O- | sudo apt-key add -
__________________________________________________________________________

Los amigos de Google mantienen un repositorio para todas sus cada vez mas inevitables apps.
Comando apt:
deb http://dl.google.com/linux/talkplugin/deb/ stable main
Secure Key:
wget -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | sudo apt-key add -
__________________________________________________________________________

Wine, como olvidarlo.
Comando apt:
ppa:ubuntu-wine/ppa
__________________________________________________________________________

Medibuntu, hasta la fecha siguen manteniendo los non-free codecs, la libreria libdvdcss2 para realizar copias de DVD originales y el mencoder un conversor de video alternativo al ffmpeg y para mi el mejor para convertir avi a divx
Comando apt:
sudo -E wget --output-document=/etc/apt/sources.list.d/medibuntu.list http://www.medibuntu.org/sources.list.d/$(lsb_release -cs).list && sudo apt-get --quiet update && sudo apt-get --yes --quiet --allow-unauthenticated install medibuntu-keyring && sudo apt-get --quiet update
__________________________________________________________________________

Jdownloader, un gran administrador de descargas, hoy por hoy un tanto en desuso al caer megaupload, pero igualmente sirve.
Comando apt:
ppa:jd-team/jdownloader
__________________________________________________________________________

Geany, por escandalo el mejor editor para PHP, Javascript y HTML en general. Si no lo conocen, pruebenlo. Y despues me cuentan.
Comando apt:
ppa:geany-dev/ppa
__________________________________________________________________________

Kazam Screencaster. Un "screencaster" es una aplicación que sirve para grabar en video lo que se hace en el escritorio. Muy útil para realizar manuales. En este caso, la aplicación anda muy bien.
Comando apt:
ppa:kazam-team/stable-series
__________________________________________________________________________

lunes, marzo 26, 2012

Configuración Internet APN CLARO ARGENTINA

En el escritorio del teléfono hacemos click en el botón de opciones -> Ajustes -> Conex. Inalámbricas y Redes -> Redes Móviles -> Nombre de puntos de acceso -> (Botón de opciones)-> Nuevo APN

NOMBRE: Claro AR
APN: internet.ctimovil.com.ar
Proxy: nada
Puerto: nada
NOMBRE DE USUARIO: ctigprs
CONTRASEÑA: ctigprs999
SERVIDOR: nada
MMSC: nada
PROXY MMS: nada
PUERTO MMS: nada
MCC: 722
MNC: 310
TIPO DE AUTENTICACION: PAP (muy importante poner esto asi)
TIPO DE APN: default,dun

Anda espectacular. Después de mucho recorrer lo encontré aquí: http://www.grupoandroid.com/topic/32939-solucion-apn-claro-ar/

Actualización 13/08/2012:
Anda dando vueltas otro APN, anda muy bien, ahi van los datos:

NOMBRE: ba.amx
APN: ba.amx
Proxy: nada
Puerto: nada
NOMBRE DE USUARIO: clarogprs
CONTRASEÑA: clarogprs999
SERVIDOR: nada
MMSC: nada
PROXY MMS: nada
PUERTO MMS: nada
MCC: 722
MNC: 310
TIPO DE AUTENTICACION: PAP (muy importante poner esto asi)
TIPO DE APN: default,dun

Actualización 5/11/2012:
NOMBRE: Claro AR
APN: igprs.claro.com.ar
Proxy: nada
Puerto: nada
NOMBRE DE USUARIO: ctigprs
CONTRASEÑA: ctigprs999
SERVIDOR: nada
MMSC: nada
PROXY MMS: nada
PUERTO MMS: nada
MCC: 722
MNC: 310
TIPO DE AUTENTICACION: PAP (muy importante poner esto asi)
TIPO DE APN: default,supl


Es el que me viene por defecto en el Samsung Galaxy S3 y está andando perfectamente bien. De hecho intenté utilizar el ba.amx y me dejo de recibir mensajes MMS. Ojalá les sirva.

Saludos!

miércoles, febrero 29, 2012

SAMSUNG GALAXY FIT S5670L - UBUNTU + ANDROID: W/ddms: Unable to get frame buffer: device (????????????) request rejected: insufficient permissions for device

Tengo un SAMSUNG GALAXY FIT S5670L y estoy comenzando con Android. Me baje el SDK de la pagina correspondiente y cuando quiero ejecutar ./ddms o el ./adb me da el siguiente mensaje:

W/ddms: Unable to get frame buffer: device (????????????) request rejected: insufficient permissions for device

y la aplicación gráfica se ve así:

 

fui a la carpeta /etc/udev/rules.d y cree el archivo de texto 51-android.rules con el siguiente contenido:

SUBSYSTEM=="usb", ATTRS{idVendor}=="04e8", ATTRS{idProduct}=="689e", MODE="0666"

donde el idVendor y el idProduct lo obtuve de hacer un lsusb
 
Bus 002 Device 062: ID 04e8:689e Samsung Electronics Co., Ltd.

luego ejecuté: sudo reload udev
y voilá cuando fui al ./ddms se vió asi:


(ojo tuve que desconectar y reconectar el teléfono.) recordar también que tiene que estar en modo debugger.

Dejo 2 enlaces muy útiles:

http://www.xatakandroid.com/tutoriales/como-mover-mas-aplicaciones-a-la-sd-sin-ser-root

http://www.xatakandroid.com/tutoriales/como-hacer-capturas-de-pantalla-en-tu-movil-android

jueves, febrero 16, 2012

Grosso! (infelizmente aplicable a mi Argentina de hoy...)


Cuando la mitad de las personas llegan a la conclusión de que ellas no tienen que trabajar porque la otra mitad está obligada a hacerse cargo de ellas, y cuando esta otra mitad se convence de que no vale la pena trabajar porque alguien les quitará lo que han logrado con su esfuerzo, eso... mi querido amigo... es el fin de cualquier Nación.

"No se puede multiplicar la riqueza dividiéndola". 
  

Dr. Adrian Rogers, 1931