103 lines
3.3 KiB
PHP
103 lines
3.3 KiB
PHP
<?php
|
|
|
|
// URL de la page à analyser
|
|
$url = 'https://www.sabradou.com/index.php';
|
|
|
|
// Récupération du contenu de la page
|
|
$html = file_get_contents($url);
|
|
|
|
// Création d'un objet DOMDocument
|
|
$dom = new DOMDocument();
|
|
libxml_use_internal_errors(true); // Ignore les erreurs de parsing HTML
|
|
$dom->loadHTML($html);
|
|
libxml_clear_errors();
|
|
|
|
// Recherche du div avec l'id "sommaire-centre"
|
|
$sommaireCentreDiv = $dom->getElementById('sommaire-centre');
|
|
|
|
// Recherche des balises <li> dans le div
|
|
$liElements = $sommaireCentreDiv->getElementsByTagName('li');
|
|
|
|
// Tableau pour stocker les villes et leurs coordonnées
|
|
$cities = array();
|
|
|
|
// Parcourir les balises <li> et extraire le texte cliquable des liens
|
|
foreach ($liElements as $liElement) {
|
|
// Vérifier s'il y a un lien dans le <li>
|
|
$linkElement = $liElement->getElementsByTagName('a')->item(0);
|
|
if ($linkElement) {
|
|
$ville = $linkElement->nodeValue;
|
|
$href = $linkElement->getAttribute('href');
|
|
//echo $ville . "<br />";
|
|
//echo "Lien : " . $href . "<br />";
|
|
|
|
// Requête à l'API Nominatim
|
|
$options = array(
|
|
'http' => array(
|
|
'header' => "User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3",
|
|
),
|
|
);
|
|
$context = stream_context_create($options);
|
|
$url = 'https://nominatim.openstreetmap.org/search?city=' . urlencode($ville) . '&format=json';
|
|
$response = file_get_contents($url, false, $context);
|
|
$data = json_decode($response, true);
|
|
|
|
// Vérifier si la requête a réussi
|
|
if (!empty($data)) {
|
|
// Récupérer les coordonnées géographiques de la première correspondance
|
|
$latitude = $data[0]['lat'];
|
|
$longitude = $data[0]['lon'];
|
|
|
|
//echo "Latitude : " . $latitude . "<br />";
|
|
//echo "Longitude : " . $longitude . "<br />";
|
|
|
|
// Ajouter la ville et ses coordonnées au tableau
|
|
$cities[] = array(
|
|
'name' => $ville,
|
|
'lat' => $latitude,
|
|
'lon' => $longitude
|
|
);
|
|
} else {
|
|
echo "Erreur : Impossible de géocoder la ville.";
|
|
}
|
|
}
|
|
}
|
|
|
|
?>
|
|
|
|
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<title>Carte OpenStreetMap</title>
|
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/leaflet/1.7.1/leaflet.css" />
|
|
<style>
|
|
#map {
|
|
height: 400px;
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<div id="map"></div>
|
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/leaflet/1.7.1/leaflet.js"></script>
|
|
<script>
|
|
// Tableau des villes et des coordonnées
|
|
var cities = <?php echo json_encode($cities); ?>;
|
|
|
|
// Créer la carte
|
|
var map = L.map('map').setView([48.8566, 2.3522], 13);
|
|
|
|
// Ajouter une couche de tuiles OpenStreetMap à la carte
|
|
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
|
|
attribution: 'Carte OpenStreetMap'
|
|
}).addTo(map);
|
|
|
|
// Placer des marqueurs pour chaque ville sur la carte
|
|
cities.forEach(function(city) {
|
|
var marker = L.marker([city.lat, city.lon]).addTo(map);
|
|
marker.bindPopup(city.name);
|
|
});
|
|
</script>
|
|
</body>
|
|
</html>
|