PDA

View Full Version : [swift+ios]sync con db su server.


yakumat
12-09-2016, 08:00
ciao a tutti!
sto sviluppare un applicazione che legga un qrcode e si confronti con un db è verifichi se sia presente o meno.
il db sarebbe su un server. l'app dovrebbe permettermi di scaricare il db in locale perchè deve poter funzionare anche senza connessione internet.
per quanto riguarda il riconoscimento con qrcode, ho trovato dei tutorial che aiutano ad implementarlo tramite la libreria AVFoundation a questo link:

https://www.appcoda.com/qr-code-reader-swift/

mentre sto avendo difficoltà a capire come poter fare la sync con il db.
è da poco che smanetto con xcode quindi devo imparare ancora molte cose. se qualcuno è pratico e potrebbe aiutarmi o quantomeno indirizzarmi, glie ne sarei davvero molto grato. :)

les2
12-09-2016, 10:58
ciao,
non è tanto xcode o swift, ma l'approccio invece.
il server dovrebbe essere un webserver che risponde con la lista dei dati che vuoi storicizzare (con i relativi livelli di sicurezza se ti servono).

un esempio è che tu faccia una chiamata ad un servizio web che risponde in json (o xml) e dentro alla risposta hai il tuo elenco da salvare in locale.
a quel punto lo agigorni tutte le volte che hai connessione o che ci sono differenze.

questo in un caso standard, potresti invece aver bisongo di:
1) un db locale in sqlite
2) se sei su rete privata ccedere diretamente al db (non credo sia il caso)

ciao

yakumat
12-09-2016, 11:12
ciao,
non è tanto xcode o swift, ma l'approccio invece.
il server dovrebbe essere un webserver che risponde con la lista dei dati che vuoi storicizzare (con i relativi livelli di sicurezza se ti servono).

un esempio è che tu faccia una chiamata ad un servizio web che risponde in json (o xml) e dentro alla risposta hai il tuo elenco da salvare in locale.
a quel punto lo agigorni tutte le volte che hai connessione o che ci sono differenze.

questo in un caso standard, potresti invece aver bisongo di:
1) un db locale in sqlite
2) se sei su rete privata ccedere diretamente al db (non credo sia il caso)

ciao

intanto grazie :) !
credo che la soluzione standard con le chiamate JSON non sia attuabile per il fatto che l'app deve potersi confrontare soprattutto offline con il db. a questo punto credo che l'utilizzo di SQLlite possa essere una soluzione. non ho mai usato sqllite... non ho idea di come implementarlo. ora inizio a googlare un po

les2
12-09-2016, 11:35
occhio che un json compresso pesa davvero poco e per il webserver comprimerlo e criptarlo non cuba troppa cpu (ovviamente se hai immense chiamate sì).

:)

ps. dovrebbero esserci le librerie native, io l'avevo usato con objective c.

yakumat
12-09-2016, 11:54
occhio che un json compresso pesa davvero poco e per il webserver comprimerlo e criptarlo non cuba troppa cpu (ovviamente se hai immense chiamate sì).

:)

ps. dovrebbero esserci le librerie native, io l'avevo usato con objective c.

si ho guardato ed è nativo sqlite.
per le chiamate: ne farebbe una all'inizio per scaricare tutto il db. una volta fatto lavora con quello in locale. alla fine dovrebbe riuppare il db con le opportune modifche e sovrascriverlo a quello su server.
con JSON posso scaricare un db con un unica chiamata?

edit: ho trovato questo su stackoverflow:
http://stackoverflow.com/questions/16540702/how-to-get-data-from-server-and-install-in-sqlite

tomminno
12-09-2016, 16:27
si ho guardato ed è nativo sqlite.
per le chiamate: ne farebbe una all'inizio per scaricare tutto il db. una volta fatto lavora con quello in locale. alla fine dovrebbe riuppare il db con le opportune modifche e sovrascriverlo a quello su server.
con JSON posso scaricare un db con un unica chiamata?

edit: ho trovato questo su stackoverflow:
http://stackoverflow.com/questions/16540702/how-to-get-data-from-server-and-install-in-sqlite

Se l'app deve solo leggere il db è un conto, ma se deve anche aggiornarlo è un bel problema prevederlo con una gestione offline. Se 2 app (figuriamoci quando sono centinaia) leggono il db centralizzato e applicano entrambe delle modifiche offline hai un problema di consistenza dei dati, specialmente se questo aggiornamento sulla versione centralizzata arriva molto in differita rispetto alla modifica dei dati apportata dalle singole app e che magari hanno comportato dei side-effect nel comportamento delle varie app che potrebbero risultare sbagliati alla luce del "merge" delle varie versioni del database. In caso di conflitti delle varie modifiche poi non è detto che sia decidibile automaticamente quale deve essere la versione corretta del database centrale.

yakumat
12-09-2016, 17:54
Se l'app deve solo leggere il db è un conto, ma se deve anche aggiornarlo è un bel problema prevederlo con una gestione offline. Se 2 app (figuriamoci quando sono centinaia) leggono il db centralizzato e applicano entrambe delle modifiche offline hai un problema di consistenza dei dati, specialmente se questo aggiornamento sulla versione centralizzata arriva molto in differita rispetto alla modifica dei dati apportata dalle singole app e che magari hanno comportato dei side-effect nel comportamento delle varie app che potrebbero risultare sbagliati alla luce del "merge" delle varie versioni del database. In caso di conflitti delle varie modifiche poi non è detto che sia decidibile automaticamente quale deve essere la versione corretta del database centrale.

Alla fine ho optato per un approccio diverso. Invece di scaricare il db modificarlo e sovrascriverlo, scarico una vista coi dati che mi servono, faccio le operazioni che mi servono e faccio una insert su una tabella slegata da tutte le altre. In questo modo non dovrei avere il problema che dici, in quanto ogni insert genererà un nuovo record

EDIT:
invece di usare le classi interne di swift per la gestione delle connessioni(come NSURLSession), ho deciso di usare un framework di terze parti:
https://github.com/Alamofire/Alamofire
che sulla carta dovrebbe semplificarmi la vita...

yakumat
14-09-2016, 08:32
alamofire non mi ha semplificato la vita :D

sono talmente stupido che ho trovato difficolta a capirne il funzionamento...
ho ripiegato su questa ottima guida in italiano:

https://www.xcoding.it/tutorial-introduttivo-al-parsing-json-in-swift/

da giusto un infarinatura di quello che sarebbe la gestione del network con swift, ma è già abbastanza per quello che devo fare.

il problema è che in fase di parsing dell'oggetto NSData ( tramite la funzione: json_parseData() ), mi si solleva l'eccezione e mi printa in console:

"[ERROR] An error has happened with parsing of json data"

da nabbo di REST API e JSON non capisco se io possa effettivamente fornire un json in questo modo: semplicemente salvandolo in un percorso sul server, prendere il link a tale percorso e sbatterlo dentro la funzione weather_request() (ovviamente con opportune modifiche).
il mio file json è statico. non deve essere generato dinamicamente dal server. quello è e quello sarà per sempre.
qualche idea? o se avete capito dove sbaglio... vi potrei amare :D

EDIT: il problema era il formato del JSON. ho scoperto questa comodissima utility per la validazione:

https://jsonformatter.curiousconcept.com/