GIS and Media fusion

"The explosive growth of the GeoWeb and geographic information has made GIS powerful media for the general public to communicate, but perhaps more importantly, GIS have also become media for constructive dialogs and interactions about social issues." - Sui & Goodchild

User Tools

Site Tools


geoinf15:postgis0

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
geoinf15:postgis0 [2015/11/16 09:23]
oertz [Géoservice Get4Capitals.php]
geoinf15:postgis0 [2018/05/16 10:05] (current)
Line 1: Line 1:
 ====== Spatial database :: PostGIS ====== ====== Spatial database :: PostGIS ======
 Voyons comment utiliser l'​extension PostGIS de PostgreSQL pour stocker et gérer de l'​information géographique dans un SGBD. Voyons comment utiliser l'​extension PostGIS de PostgreSQL pour stocker et gérer de l'​information géographique dans un SGBD.
- 
-===== Installation avec OpenShift ===== 
-{{:​geoinf15:​openshift_logo_wide_blk250.png?​nolink|}} 
-  - Déployer une application PHP/​PGSQL+PostGIS avec OpenShift (https://​www.openshift.com) 
-    * Créer un compte OpenShift par ce lien : https://​openshift.redhat.com/​app/​account/​new?​then=%2Fapp%2Fconsole 
-    * Suivre le lien "​Create first application now" 
-    * Choisir le **cartdrige PHP5.4** {{:​geoinf15:​screenshot_from_2015-11-02_23_33_09.png?​nolink|}} 
-    * Définir un nom de domaine rhcloud.com et le nom de préfixe correspondant à l'​application (ex. //​geoinf-oertz.rhcloud.com//​) 
-    * (__remarque :__ si la création prend du temps, démarrer les points 2 et 3 en parallèle) 
-    * A la question "Will you change your code ...", répondre non 
-    * Depuis la web console et dans la configuration de l'​application,​ ajouter le **cartdrige PostgreSQL 9.2** 
-    * Conserver les crédentials 
-  - Installer **pgadmin** : http://​www.pgadmin.org/​ 
-  - Installer le **client tool rhc** : https://​developers.openshift.com/​en/​getting-started-overview.html 
-  - Lancer une session rhc en ligne de commande depuis une console OS : 
-    * Exécuter : <​code>​rhc setup</​code>​ 
-    * Valider le server name par défaut 
-    * Saisir le login OpenShift et mot de passe 
-    * A la question sur le token, pour éviter la resaisie de mot de passe, répondre oui 
-    * A la question sur la paire de clés SSH, répondre oui 
-    * Exécuter : <​code>​rhc port-forward -a myAppName</​code>​ 
-  - Lancer pgadmin 
-    * Créer une connexion sur l'IP (et le port) forwardée par la commande ci-dessus sur la ligne PostgreSQL 
-    * Saisir les crédentials et se connecter 
-    * Vérifier le nombre de tables dans la BD (normalement aucune) 
-    * Exécuter dans la console SQL : <​code>​create extension postgis;</​code>​ 
-    * Vérifier le nombre de tables, de vues et de fonctions (normalement beaucoup) 
-    * Tout est prêt ! 
  
 ===== Une première "​geotable"​ ===== ===== Une première "​geotable"​ =====
Line 54: Line 26:
 </​code>​ </​code>​
  
-===== Géoservice Get4Capitals.php ===== 
-Cet exemple montre comment créer un service sur mesure qui va //publier// l'​information géographique de la géotable. Il est notamment fait usage du format GeoJSON pour transmettre ces données au client. OpenLayers saura par exemple l'​exploiter facilement au travers d'une couche ol.Vector et le format ol.format.GeoJSON. 
- 
-<​code>​ 
-<?php 
-require_once '​GeoManager.php';​ 
-$conn = new Connection("​host=127.0.0.1 port=5432 dbname=php user=admintoto password=blablatutu"​);​ 
- 
-$query = "​SELECT name, ST_AsGeoJSON(the_geom) from my4capitals";​ 
-$result = $conn->​selectQuery($query);​ 
- 
-$i = 0; 
-$fc = new FeatureCollection();​ 
-while ($row = pg_fetch_row($result)) { 
-    $fc->​addFeature(new Feature($i++,​ (json_decode($row[1])),​ array("​name"​ => $row[0]))); 
-} 
-echo json_encode($fc);​ 
-?> 
-</​code>​ 
- 
-On a besoin d'un GeoManager (GeoManager.php) qui sait gérer les requêtes avec la geodatabase et encoder les résultats par un flux GeoJSON. 
-<​code>​ 
-<?php 
-class Connection { 
- 
-    private $CONFIG; 
-    private $CONN; 
- 
-    function __construct($cfg) { 
-        $this->​CONFIG = $cfg; 
-        return $this->​CONN = pg_connect($this->​CONFIG) or die('​connection failed'​);​ 
-    } 
- 
-    function selectQuery($query) { 
-        $result = pg_query($this->​CONN,​ $query); 
-        if (!$result) throw new ErrorException($query);​ 
-        return $result; 
-    } 
- 
-    function insertQuery($query) { 
-        pg_query($this->​CONN,​ "BEGIN WORK"​);​ 
-        $result = pg_query($this->​CONN,​ $query); 
-        if (!$result) { 
-            pg_query($this->​CONN,​ "​ROLLBACK"​);​ 
-        } else { 
-            pg_query($this->​CONN,​ "​COMMIT"​);​ 
-        } 
-    } 
-} 
- 
-class Feature 
-{ 
- var $type; 
- var $geometry; 
- var $id; 
- var $properties;​ 
- 
- function Feature($id,​$geom,​$properties) { 
- $this->​type = "​Feature";​ 
- $this->​geometry = $geom; 
- $this->​id = $id; 
- $this->​properties = $properties;​ 
-              
- } 
-} 
- 
-class FeatureCollection 
-{ 
- var $type; 
- var $features; 
-  
- function FeatureCollection() 
- { 
- $this->​type = "​FeatureCollection";​ 
- $this->​features = array(); 
- } 
-  
- function addFeature($feature) { 
- array_push($this->​features,​$feature);​ 
- 
-} 
-?> 
-</​code>​ 
- 
-__TODO__ 
-  - Tester ce géoservice et analyser les différentes étapes du processus (veiller à reconfigurer les paramètres de connexion) - évt utiliser l'​astuce de Daniel http://​mediamaps.ch/​wiki/​doku.php?​id=geoinf14:​postgis0 
-  - Terminer l'​exemple en exploitant le géoservice dans OpenLayers avec une ol.layer.Vector comme vu dans [[geoinf15:​ol3tuto#​ex5asource_de_donnees_openlayersformat|Ex5A]]. 
  
geoinf15/postgis0.1447662185.txt.gz · Last modified: 2018/05/16 10:05 (external edit)