Vous êtes ici Codes PHP et MySQL > Inclassable > WIKILOC : exemple de réception d'un SMS + géoloc...

 

WIKILOC : exemple de réception d'un SMS + géoloc de l'expéditeur dans une page PHP

WikiLoc permet de recevoir l'article Wikipedia le plus pertinent proche de l'endroit ou vous vous situez. Il suffit d'envoyer depuis une ligne SFR, le SMS : "#wikiloc# wiki" au 6010. Vous recevez dans les 5 minutes, la réponse par SMS sous forme d'un lien cliquable. Ce service ne fonctionne qu'avec des lignes SFR.
il est également possible d'obtenir un numéro court pour ne plus avoir besoin du #wikiloc# en envoyant "#wikiloc# short" au 6010.

Les requêtes ont été construites via l'API Test Tool de SFR API. Il est conseiller de s'inscrire pour utiliser votre propre identifiant plutôt que l'identifiant de l'exemple dont le compteur de crédits peut être épuisé.

Le code PHP, doit être appelé automatiquement a fréquence régulière via un cron afin d'analyser la file des SMS entrants. Dans notre exemple, ce code est hébergé chez free et régulièrement appelé par cronjobonline.
 
hhoareau
Site de l'auteur voir
Code vu 3711 fois
Enregistré le 22 Fév 2011
  • Digg ce code sur digg.com
  • Bookmark ce code sur del.icio.us
  • Bookmark ce code sur Google
  • Bookmark ce code sur Yahoo
  • Ajoute WIKILOC : exemple de réception d'un SMS + géoloc de l'expéditeur dans une page PHP
  • Partage ce code sur Facebook
 
 
 
 

Code Source


01.
02.
03.
04.
05.
06.
07.
08.
09.
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.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
101.
102.
103.
104.
105.
106.
107.
108.
109.
110.
111.
112.
113.
114.
115.
116.
117.
118.
119.
120.
121.
122.
123.
124.
125.
126.
127.
128.
129.
130.
131.
132.
133.
134.
135.
136.
137.
138.
139.
140.
141.
142.
 
<?php
/******************************************************************************/
/*                                                                            */
/*                       __        ____                                       */
/*                 ___  / /  ___  / __/__  __ _____________ ___               */
/*                / _ \/ _ \/ _ \_\ \/ _ \/ // / __/ __/ -_|_-<               */
/*               / .__/_//_/ .__/___/\___/\_,_/_/  \__/\__/___/               */
/*              /_/       /_/                                                 */
/*                                                                            */
/*                                                                            */
/******************************************************************************/
/*                                                                            */
/* Titre          : WIKILOC : exemple de réception d'un SMS + géoloc de...    */
/*                                                                            */
/* URL            : http://www.phpsources.org/scripts624-PHP.htm              */
/* Auteur         : hhoareau                                                  */
/* Date édition   : 22 Fév 2011                                               */
/* Website auteur : api.sfr.fr                                                */
/*                                                                            */
/******************************************************************************/


//TOKEN généré à titre de demonstration par SFR
//le nombre de SMS disponibles sur ce compte peut être épuisé
//il est conseiller de vous inscrire sur api.sfr.fr pour obtenir votre propre
// token
define("DEVTOKEN","81e3d203dd52a852fa986624c718929c");

// RestRequest est une fonction générique pour exécuter des requêtes REST en PHP
// 
// cette fonction utilise fopen. Elle est compatible avec l'hébergement gratuit
// chez Free.
function RestRequest ($url$method='GET'$data=null$optional_headers null)
 {
  $params = array('http' => 
                  array('method'=>$method, 
                        'content'=>$data,
                          'timeout'=>20
                  ));
                               
  if ($optional_headers !== null) {$params['http']['header'] = $optional_headers
;}
 
  $ctx stream_context_create($params);
  $fp = @fopen($url'rb'false$ctx);
 
  if (!$fp) {
      //throw new Exception("Problem with $url, $php_errormsg");
      echo("Requete en echec\n");
      return(null);
  }
  $response = @stream_get_contents($fp);
 
  if ($response === false) {throw new Exception(
"Problem reading data from $url, $php_errormsg");}
 
  return $response;
}
    

    //Le code principale est appellé régulièrement via un cron
    //Sur cronjobonline il est possible de mettre en place  
    //gratuitement un appel régulier pour une page php.
    
    //Via la méthode Consume on interroge la file des SMS entrants
    
//cette méthode à été construite via l'API Test Tool d'SFR API :
// api.sfr.fr/apitesttool
    $event=simplexml_load_string(RestRequest(
"http://ws.red.sfr.fr/red-ws/red-b2c/resources/event/consume?responseType=xml" .
"&token=".DEVTOKEN));
    if($event->redEvent->eventCode==11)
    {    
        //On récupére le numéro de l'expéditeur
        $exp=$event->redEvent->eventSource;

        //Si le message est "wiki"...    
        if(strtolower($event->redEvent->eventMessage)=="wiki"){

            //... On géolocalise la ligne émetrice
            
//la première fois il faut qu'elle confirme qu'elle accepte d'être géolocalisée
// par WikiLoc
            //si elle confirme la localization peut être réalisée
            $url=
"http://ws.red.sfr.fr/red-ws/red-b2c/resources/loc/localize?responseType=xml&" .
"token=".DEVTOKEN.
                "&userIdentifier=".$exp."&type=PhoneNumber";
            $rc=simplexml_load_string(RestRequest($url));
            
            //Si la localisation a pu être réalisée errorcode=0 ... 
            if(($rc)&&($rc->errorCode==0)){
                $lng=$rc->location->longitude;
                $lat=$rc->location->latitude;
                
                
//... On interroge le service geoname pour récupéré les articles wikipedia les
// plus proches
                
//Le service est interogé avec le username "sfrapi", il est conseiller de vous
// inscrire
                //afin d'utiliser votre propre compte
                $xml=simplexml_load_string(RestRequest(
"http://api.geonames.org/findNearbyWikipedia?lat=".$lat."&lng=".$lng.
"&username=sfrapi&style=full"));    
                if($xml)
                    
//puis on recherche l'article le plus pertinent dans la liste des articles
                    //retournés par geoname
                    for($i=0;$i<count($xml->entry);$i++){
                        $article=$xml->entry[$i];
                        if($article->rank>$max){$max=$article->rank;$best=
$article;}
                    }
                
                
//Enfin le lien vers l'article le plus pertinent est renvoyé via SMS au
// demandeur.
                RestRequest(
"http://ws.red.sfr.fr/red-ws/red-b2c/resources/sms/send?responseType=xml&token="
.DEVTOKEN."&to=".$exp."&type=PhoneNumber&msg=".$best->wikipediaUrl);
            }        
        }

        
//Si le message est "short" on affecte un numéro court à l'expéditeur qui
        
//pourra être utilisé pour éviter l'usage du 6010 avec l'alias #wikiloc#
        if(strtolower($event->redEvent->eventMessage)=="short"){
            $xml=simplexml_load_string(RestRequest(
"http://ws.red.sfr.fr/red-ws/red-b2c/resources/shortcode/generateSmsShortcode" .
"?responseType=json&token=".DEVTOKEN."&msisdn=".$exp));
            if($xml->errorCode==0)
                RestRequest(
"http://ws.red.sfr.fr/red-ws/red-b2c/resources/sms/send?responseType=xml&token="
.DEVTOKEN."&to=".$exp.
"&type=PhoneNumber&msg=utilisez%20ce%20numero%20pour%20interroger%20wikiloc%2" .
"0en%repondant%20wiki");        
        }    
    }    
?>

 

Fonctions du code

: Définit une constante - (PHP 4, PHP 5)
: Crée un tableau - (PHP 4, PHP 5)
: Crée un contexte de flux - (PHP 4 >= 4.3.0, PHP 5)
: Ouvre un fichier ou une URL - (PHP 4, PHP 5)
: Affiche une chaîne de caractères - (PHP 4, PHP 5)
: Lit le reste d'un flux dans une chaîne - (PHP 5)
: Convertit une chaîne XML en objet - (PHP 5)
: Renvoie une chaîne en minuscules - (PHP 4, PHP 5)
: Compte le nombre d'éléments d'un tableau ou le nombre de propriétés...
Commentaire
j'ai une table et je veux recuperer les infos de ma table sur une pas comment faire envoyer moi la reponse par email   houmbsimon@yahoo.fr 
 
Ajouter un commentaire
Code de sécurité

Attention: Les champs marqués d'une étoile * sont obligatoires
 

Connexion

 
 

Inclassable

 
 

PHP

 
 
        Publicité