IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Récupération des données dans un tableau


Sujet :

Langage PHP

  1. #1
    Membre régulier Avatar de djedje37et28
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2005
    Messages
    224
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2005
    Messages : 224
    Points : 84
    Points
    84
    Par défaut Récupération des données dans un tableau
    Bonjour

    J'utilise une API pour récupérer des données en vue de les afficher dans un formulaire de contact.

    En me basant sur le code source d'exemple ( https://documentation.emarsys.com/re...on/php-sample/ ), et sur querying contact data (https://documentation.emarsys.com/re.../contact-data/) j'obtiens les données du contact passé en get dans $mailrecup

    Cependant c'est du texte brut qu'il m'est difficile d'exploiter dans le formulaire pour préremplir le nom, la civilité....

    Ma question est donc : Est il possible de facilement récupérer ces données dans un tableau ? est ce avec preg_match ou autre ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
     
    <?php
    $mailrecup=$_GET['mail'];
     
    class SuiteApi
    {
        private
            $_username,
            $_secret,
            $_suiteApiUrl;
     
        public function __construct($username, $secret, $suiteApiUrl = 'https://api.emarsys.net/api/v2/')
        {
            $this->_username = $username;
            $this->_secret = $secret;
            $this->_suiteApiUrl = $suiteApiUrl;
        }
     
        public function send($requestType, $endPoint, $requestBody = '')
        {
            if (!in_array($requestType, array('GET', 'POST', 'PUT', 'DELETE'))) {
                throw new Exception('Send first parameter must be "GET", "POST", "PUT" or "DELETE"');
            }
     
            $ch = curl_init();
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
            switch ($requestType)
            {
                case 'GET':
                    curl_setopt($ch, CURLOPT_HTTPGET, 1);
                    break;
                case 'POST':
                    curl_setopt($ch, CURLOPT_POST, 1);
                    curl_setopt($ch, CURLOPT_POSTFIELDS, $requestBody);
                    break;
                case 'PUT':
                    curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "PUT");
                    curl_setopt($ch, CURLOPT_POSTFIELDS, $requestBody);
                    break;
                case 'DELETE':
                    curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "DELETE");
                    curl_setopt($ch, CURLOPT_POSTFIELDS, $requestBody);
                    break;
            }
            curl_setopt($ch, CURLOPT_HEADER, true);
     
            $requestUri = $this->_suiteApiUrl . $endPoint;
            curl_setopt($ch, CURLOPT_URL, $requestUri);
            $nonce = '';
            $timestamp = gmdate("c");
            $passwordDigest = base64_encode(sha1($nonce . $timestamp . $this->_secret, false));
            curl_setopt($ch, CURLOPT_HTTPHEADER, array(
                "X-WSSE: UsernameToken " .
                    "Username=\"$this->_username\", " .
                    "PasswordDigest=\"$passwordDigest\", " .
                    "Nonce=\"$nonce\", " .
                    "Created=\"$timestamp\"",
                "Content-type: application/json;charset=\"utf-8\"",
                )
            );
     
     
            $output = curl_exec($ch);
     
            curl_close($ch);
     
            return $output;
        }
    }
     
    $demo = new SuiteApi('login', 'mdp');
     
    echo $demo->send('POST', 'contact/getdata', '{ "keyId": "3",
      "keyValues": ["'.$mailrecup.'"],
      "fields": [1,2,3,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20]}') . "\n\n";
     
     
      ?>
    Voici ce que ça retourne :

    HTTP/1.1 200 OK Server: openresty/1.7.4.1 Date: Tue, 05 Jan 2016 16:20:47 GMT Content-Type: text/html; charset=utf-8 .......... Vary: Accept-Encoding X-fe: suiteapipxy01.emarsys.at {"replyCode":0,"replyText":"OK","data":{"errors":[],"result":[{"id":"mon id","uid":"mon uid","1":"prénom","2":"nom","3":"test@aol.com","5":null,"6":null,"7":null,"8":null,"9":null,"10":null,"11":null,"12":null,"13":null,"14":null,"15":null,"16":null,"17":null,"18":"societe","19":null,"20":null}]}}

    Idéalement j'aimerai récupérer les fields (1,2,3...).

    Merci

  2. #2
    Membre régulier
    Homme Profil pro
    Datascientist
    Inscrit en
    Août 2008
    Messages
    248
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Datascientist
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2008
    Messages : 248
    Points : 110
    Points
    110
    Par défaut
    Bonjouur,

    si j'ai bien compris tu veux mettre ça
    "data":{"errors":[],"result":[{"id":"mon id","uid":"mon uid","1":"prénom","2":"nom","3":"test@aol.com","5":null,"6":null,"7":null,"8":null,"9":null,"10":null,"11":null,"12":null,"13":null,"14":null,"15":null,"16":null,"17":null,"18":"societe","19":null,"20":null}
    dans un tableau si oui tu peux utiliser 2 fois (explode) dans deux boucles
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    array explode ( string $delimiter , string $string [, int $limit ] )
    la première tu mets comme délimiteur ","
    la deuxième tu mets comme délimiteur ":"

    bonne chance

  3. #3
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2016
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2016
    Messages : 42
    Points : 60
    Points
    60
    Par défaut
    Salut,

    Supprime la ligne 45 pour ne pas avoir d'en-têtes dans la réponse.

    Ensuite tu peux utiliser la fonction json_decode() sur la réponse.

    http://php.net/manual/fr/function.json-decode.php

    ++

  4. #4
    Membre régulier Avatar de djedje37et28
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2005
    Messages
    224
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2005
    Messages : 224
    Points : 84
    Points
    84
    Par défaut
    Bonjour,

    Je veux récupérer ce qui est contenu dans result à savoir
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    uid","1":"prénom","2":"nom","3":"test@aol.com","5":null,"6":null,"7":null,"8":null,"9":null,"10":null,"11":null,"12":null,"13":null,"14":null,"15":null,"16":null,"17":null,"18"
    J'ai fait avec fonction json_decode du coup :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $demo->send('POST', 'contact/getdata', '{ "keyId": "3",
      "keyValues": ["'.$mailrecup.'"],
      "fields": [1,2,3]}') . "\n\n";
     
    var_dump(json_decode($demo));
    var_dump(json_decode($demo, true));
     
    $error = json_last_error();
     
    var_dump($demo, $error === JSON_ERROR_UTF8);
    J'obtiens En demandant les erreurs, j'obtiens ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    NULL NULL object(SuiteApi)#1 (3) { ["_username":"SuiteApi":private]=> string(15) "login" ["_secret":"SuiteApi":private]=> string(20) "mdp" ["_suiteApiUrl":"SuiteApi":private]=> string(31) "https://api.emarsys.net/api/v2/" } bool(false)
    Est ce que j'ai loupé quelque chose ?

  5. #5
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2016
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2016
    Messages : 42
    Points : 60
    Points
    60
    Par défaut
    Re,

    Supprime la ligne 45 pour ne pas avoir d'en-têtes dans la réponse.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
        $resp = $demo->send('POST', 'contact/getdata', '{ "keyId": "3", "keyValues": ["'.$mailrecup.'"], "fields": [1,2,3]}');
        $resp = json_decode($resp);
     
        var_dump($resp);
    ++

  6. #6
    Membre régulier Avatar de djedje37et28
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2005
    Messages
    224
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2005
    Messages : 224
    Points : 84
    Points
    84
    Par défaut
    Merci Jeremy!

    Est ce qu'on peut récupérer uniquement la valeur contenu dans id ou uid ... ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    object(stdClass)#2 (3) { ["replyCode"]=> int(0) ["replyText"]=> string(2) "OK" ["data"]=> object(stdClass)#3 (2) { ["errors"]=> array(0) { } ["result"]=> array(1) { [0]=> object(stdClass)#4 (5) { ["id"]=> string(9) "123" ["uid"]=> string(10) "123j" ["1"]=> string(6) "jerome" ["2"]=> string(11) "fag" ["3"]=> string(27) "jerome.fag@hotmail.fr" } } } }

  7. #7
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2016
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2016
    Messages : 42
    Points : 60
    Points
    60
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <?php $resp->data->result[0]->id; ?>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <?php $resp->data->result[0]->uid; ?>
    ++

  8. #8
    Membre régulier Avatar de djedje37et28
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2005
    Messages
    224
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2005
    Messages : 224
    Points : 84
    Points
    84
    Par défaut
    Merci c'est super ! je rajouterai juste que si la valeur est un numérique il faut écrire !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $resp->data->result[0]->{'2'};

Discussions similaires

  1. Réponses: 6
    Dernier message: 17/07/2006, 15h07
  2. [MySQL] Formatage des données dans un tableau
    Par dunbar dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 26/06/2006, 08h52
  3. [MySQL] Stocker des données dans un tableau
    Par LadyArwen dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 02/02/2006, 10h40
  4. Réponses: 3
    Dernier message: 05/12/2005, 02h30

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo