gestionidautore.it è interfacciabile direttamente con il Vs sito web tramite l'utilizzo di CURL. L'URL verso cui puntare il post è https://www.gestionidautore.it/api/put.
Ad ogni lotto di attestazione viene associata una API Key che consente l'autenticazione dell'utente tramite un unica stringa alfanumerica.
Per poter effettuare il post delle immagini da un sito remoto occorre seguire i seguenti passaggi:
$post = array('apikey' => $apikey,'url' => $url_to_jpeg,'title' => $title,'year' => $year_photo,);
Creare un array che contenga l'API key, l'url all'immagine da depositare, il titolo e l'anno di pubblicazione secondo le schema sopra riportato. Nell'array sopra riprodotto tali valori sono valorizzati in quattro variabili distinte: $apikey, $url_to_jpeg, $title, e $year_photo.
$curl = curl_init();curl_setopt_array($curl, [CURLOPT_URL => "https://www.gestionidautore.it/api/put",CURLOPT_RETURNTRANSFER => true,CURLOPT_ENCODING => "",CURLOPT_MAXREDIRS => 10,CURLOPT_TIMEOUT => 30,CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,CURLOPT_CUSTOMREQUEST => "POST",CURLOPT_POSTFIELDS => $post,]);$response = curl_exec($curl);$info = curl_getinfo($curl);$err = curl_error($curl);if($response === false){echo "Errore: ". curl_error($curl)." - Codice errore: ".curl_errno($curl);}curl_close($curl);$result = json_decode($response, true);$success = $result['success'];
Effettuare il post con CURL dell'array creato con il primo step. L'output al post viene restituito in formato json e per prima cosa andremo a verificare il contenuto del parametro "SUCCESS" che ci consentirà di verificare se l'operazione ha avuto successo.
Se il json di risposta ha restituito la variabile $result['success']; popolata con il valore TRUE si può procedere a memorizzare all'interno di un database l'esito e tutte le informazioni inerenti il deposito dell'immagine:
Nel caso in cui il json abbia risposto, tramite la variabile $result['success']; con il valore FALSE vi è stato qualche errore nell'esecuzione del deposito. È sempre buona norma registrare l'errore al fine di poter monitorare ed intervenire su eventuali problematiche.
Qui di seguito sono riportate le strutture delle due tabelle Mysql utilizzate negli esempi.
Lo schema della tabella gestionidautore_crt è il seguente:
Lo schema della tabella gestionidautore_err è il seguente:
Guida, FAQ, PHP, API gestionidautore.it, CURL, Attestazione titolarità dei diritti d'autore, Dimostrare la paternità dell'opera, Dimostrare paternità dei diritti d'autore