Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-09-2016, 08:00   #1
yakumat
Senior Member
 
L'Avatar di yakumat
 
Iscritto dal: Mar 2011
Messaggi: 785
[swift+ios]sync con db su server.

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.
__________________
Case haf 932 - cpu i7 2600k @4.2ghz- gpu msi 570gtx twin frozr II - mb asus p8p67 b3 deluxe - psu enermax 87+ gold 850w - dissi corsair h70 - ram corsair vengeance 1600 mhz 4x2 - ssd samsung 840 pro 256Gb - hdd wd caviar black 1tb - monitor samsung bx2450 - audio xonar dx -
yakumat è offline   Rispondi citando il messaggio o parte di esso
Old 12-09-2016, 10:58   #2
les2
Senior Member
 
L'Avatar di les2
 
Iscritto dal: Mar 2001
Città: MI
Messaggi: 1801
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
__________________
italiarec.com forum italiano di registrazione e mixaggio
estilocaballero.es ssdoptimizer.eu cambioeuro.eu doflamingo.com studiolegalesangalli.com stilegentiluomo.it italiarec.com italiarec.it arteincasa.it
les2 è offline   Rispondi citando il messaggio o parte di esso
Old 12-09-2016, 11:12   #3
yakumat
Senior Member
 
L'Avatar di yakumat
 
Iscritto dal: Mar 2011
Messaggi: 785
Quote:
Originariamente inviato da les2 Guarda i messaggi
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
__________________
Case haf 932 - cpu i7 2600k @4.2ghz- gpu msi 570gtx twin frozr II - mb asus p8p67 b3 deluxe - psu enermax 87+ gold 850w - dissi corsair h70 - ram corsair vengeance 1600 mhz 4x2 - ssd samsung 840 pro 256Gb - hdd wd caviar black 1tb - monitor samsung bx2450 - audio xonar dx -
yakumat è offline   Rispondi citando il messaggio o parte di esso
Old 12-09-2016, 11:35   #4
les2
Senior Member
 
L'Avatar di les2
 
Iscritto dal: Mar 2001
Città: MI
Messaggi: 1801
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.
__________________
italiarec.com forum italiano di registrazione e mixaggio
estilocaballero.es ssdoptimizer.eu cambioeuro.eu doflamingo.com studiolegalesangalli.com stilegentiluomo.it italiarec.com italiarec.it arteincasa.it
les2 è offline   Rispondi citando il messaggio o parte di esso
Old 12-09-2016, 11:54   #5
yakumat
Senior Member
 
L'Avatar di yakumat
 
Iscritto dal: Mar 2011
Messaggi: 785
Quote:
Originariamente inviato da les2 Guarda i messaggi
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/1...tall-in-sqlite
__________________
Case haf 932 - cpu i7 2600k @4.2ghz- gpu msi 570gtx twin frozr II - mb asus p8p67 b3 deluxe - psu enermax 87+ gold 850w - dissi corsair h70 - ram corsair vengeance 1600 mhz 4x2 - ssd samsung 840 pro 256Gb - hdd wd caviar black 1tb - monitor samsung bx2450 - audio xonar dx -

Ultima modifica di yakumat : 12-09-2016 alle 14:15.
yakumat è offline   Rispondi citando il messaggio o parte di esso
Old 12-09-2016, 16:27   #6
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da yakumat Guarda i messaggi
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/1...tall-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.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 12-09-2016, 17:54   #7
yakumat
Senior Member
 
L'Avatar di yakumat
 
Iscritto dal: Mar 2011
Messaggi: 785
Quote:
Originariamente inviato da tomminno Guarda i messaggi
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...
__________________
Case haf 932 - cpu i7 2600k @4.2ghz- gpu msi 570gtx twin frozr II - mb asus p8p67 b3 deluxe - psu enermax 87+ gold 850w - dissi corsair h70 - ram corsair vengeance 1600 mhz 4x2 - ssd samsung 840 pro 256Gb - hdd wd caviar black 1tb - monitor samsung bx2450 - audio xonar dx -

Ultima modifica di yakumat : 13-09-2016 alle 11:01.
yakumat è offline   Rispondi citando il messaggio o parte di esso
Old 14-09-2016, 08:32   #8
yakumat
Senior Member
 
L'Avatar di yakumat
 
Iscritto dal: Mar 2011
Messaggi: 785
alamofire non mi ha semplificato la vita

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

https://www.xcoding.it/tutorial-intr...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

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

https://jsonformatter.curiousconcept.com/
__________________
Case haf 932 - cpu i7 2600k @4.2ghz- gpu msi 570gtx twin frozr II - mb asus p8p67 b3 deluxe - psu enermax 87+ gold 850w - dissi corsair h70 - ram corsair vengeance 1600 mhz 4x2 - ssd samsung 840 pro 256Gb - hdd wd caviar black 1tb - monitor samsung bx2450 - audio xonar dx -

Ultima modifica di yakumat : 14-09-2016 alle 09:21.
yakumat è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Larry Ellison guadagna 101 miliardi in u...
Johnson Controls amplia la gamma di solu...
NASA Perseverance: il rover potrebbe ave...
Quelli di Immuni si 'pappano' Vimeo: Ben...
Changan lancia la Deepal S05 in Europa, ...
Substrati in vetro, Intel smentisce le v...
ECOVACS DEEBOT T50 PRO OMNI Gen2 fa piaz...
Windelo 62: catamarano a vela che unisce...
Francia, in arrivo un incentivo di 1.000...
Haier, la sorpresa a IFA: la lavatrice C...
GeForce RTX 5000 SUPER in arrivo? Sembra...
Ionity prova una soluzione contro i ladr...
Pirateria, svolta clamorosa: Dazn e Lega...
Maxi richiamo Toyota e Lexus: oltre 900....
Blackwell Ultra: fino al 45% di prestazi...
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: 19:46.


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