source: trunk/info/info/alkisn/alkisausk.php @ 412

Revision 412, 10.8 KB checked in by frank.jaeger, 5 years ago (diff)

Anpassung der ALKIS-Auskunft (PHP) an die Full-Schema-Version des ALKIS-Importers 3.0

Line 
1<?php
2/*      alkisausk.php
3
4        ALKIS-Buchauskunft, Kommunales Rechenzentrum Minden-Ravensberg/Lippe (Lemgo).
5        Dies Programm wird aus dem Mapserver-Template (FeatureInfo) aufgerufen.
6        Parameter: &gkz, &gml_id (optional &id)
7        Dies Programm gibt einen kurzen Überblick zum FlurstÃŒck, z.B. Eigentuemer ohne Adresse
8        FÃŒr detaillierte Angaben wird zum GB- oder FS-Nachweis verlinkt.
9        Siehe auch alkisinlayausk.php - eine Variante fÃŒr den Einbau in einen iFrame
10
11        Version:
12        2016-02-24 Version fuer norGIS-ALKIS-Import
13        2016-11-29 HTML5, Gemeinsam genutzte Datenbanken ermöglichen (Berechtigung fÃŒr Gemeinde prÃŒfen)
14        2017-10-11 Sauber filtern auf endet IS NULL
15        2018-11-09 Umstellung Full-Schema
16
17        H i n w e i s :  Dies Modul wird beim Entwickler nicht mehr produktiv eingesetzt.
18                Statt dessen wird "alkisinlayausk.php" verwendet um von einer WMS-FeatureInfo in ein Fenster ÃŒberzuleiten.
19                Mangels Praxis bleiben Fehler möglicherweise unerkannt.
20*/
21session_start();
22$cntget = extract($_GET);
23
24require_once("alkis_conf_location.php");
25if ($auth == "mapbender") {require_once($mapbender);}
26include("alkisfkt.php");
27$keys = isset($_GET["showkey"]) ? $_GET["showkey"] : "n";
28if ($keys == "j") {$showkey=true;} else {$showkey=false;}
29echo <<<END
30<!doctype html>
31<html lang="de">
32<head>
33        <meta charset="utf-8">
34        <link rel="stylesheet" type="text/css" href="alkisauszug.css">
35        <link rel="shortcut icon" type="image/x-icon" href="ico/Flurstueck.ico">
36        <title>ALKIS-Auskunft</title>
37</head>
38<body>
39END;
40$con = pg_connect($dbconn." options='--application_name=ALKIS-Auskunft_alkisausk.php'");
41if (!$con) {echo "<br>Fehler beim Verbinden der DB.\n<br>";}
42
43// *** F L U R S T U E C K ***
44$sql ="SELECT f.flurnummer, f.zaehler, f.nenner, f.amtlicheflaeche, g.gemarkungsnummer, g.bezeichnung, f.gemeindezugehoerigkeit_regierungsbezirk, f.gemeindezugehoerigkeit_kreis, f.gemeindezugehoerigkeit_gemeinde
45FROM ax_flurstueck f LEFT JOIN ax_gemarkung g ON f.land=g.land AND f.gemarkungsnummer=g.gemarkungsnummer
46WHERE f.gml_id= $1 AND f.endet IS NULL AND g.endet IS NULL;";
47
48$v = array($gmlid);
49$res = pg_prepare("", $sql);
50$res = pg_execute("", $v);
51if (!$res) {
52        echo "\n<p class='err'>Fehler bei Flurstuecksdaten.</p>";
53        if ($debug > 2) {echo "\n<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
54}
55
56if ($row = pg_fetch_array($res)) {
57        $gemkname=htmlentities($row["bezeichnung"], ENT_QUOTES, "UTF-8");
58        $gmkgnr=$row["gemarkungsnummer"];
59        $flurnummer=$row["flurnummer"];
60        $flstnummer=$row["zaehler"];
61        $nenner=$row["nenner"];
62        if ($nenner > 0) $flstnummer.="/".$nenner; // BruchNr
63        $flae=$row["amtlicheflaeche"];
64        $flae=number_format($flae,0,",",".") . " m&#178;";
65        $fsreg=$row["gemeindezugehoerigkeit_regierungsbezirk"]; // Filter ZustÀndigkeit
66        $fskrs=$row["gemeindezugehoerigkeit_kreis"];
67        $fsgem=$row["gemeindezugehoerigkeit_gemeinde"];
68} else {
69        echo "\n<p class='err'>Kein Treffer fuer gml_id=".$gmlid."</p>";
70}
71
72// Balken
73echo "\n<p class='fsausk'>ALKIS-Auskunft Flurst&uuml;ck-&Uuml;bersicht ".$gmkgnr."-".$flurnummer."-".$flstnummer."</p>";
74
75// PrÃŒfung der Gebiets-Berechtigung bei gemeinsam genutzten Datenbanken (Kreis und Gemeinde)
76// FÃŒr das gkz (z.B. aus dem Mapfile-Namen) wird in der Konfiguration ein Filter gesetzt.
77if ( ($filtkreis != '' and $filtkreis != $fskrs) or ($filtgem != '' and $filtgem != $fsgem) ) {
78        // Einer der gesetzten Filter passt nicht
79        if ($debug > 2) {
80                echo "\n<p class='err'>Filter Kreis='".$filtkreis."', Gemeinde='".$filtgem."'</p>";
81                echo "\n<p class='err'>Flstk. Kreis='".$fskrs."', Gemeinde='".$fsgem."'</p>";
82        }
83        echo "\n<br><p class='stop1'>Zugriff nicht erlaubt</p>
84        \n<br><p class='stop2'>Dies Flurst&uuml;ck liegt ausserhalb der zust&auml;ndigen Stadt oder Gemeinde.</p>\n</body>\n</html>";
85        pg_free_result($res);
86        exit;
87}
88
89echo "\n<table class='outer'>\n<tr><td>";
90        // linke Seite
91        echo "\n<h1>ALKIS-Auskunft</h1>"
92        ."\n<h2><img src='ico/Flurstueck.png' width='16' height='16' alt=''> Flurst&uuml;ck - &Uuml;bersicht</h2>";
93echo "</td><td align='right'>";
94        // rechte Seite
95        echo "<img src='pic/AAA.gif' alt=''>"
96."</td></tr></table>";
97
98echo "\n<table class='outer'>\n<tr>\n<td>"
99        ."\n\t<table class='kennzfs' title='Flurst&uuml;ckskennzeichen'>\n\t<tr>"
100        ."\n\t\t<td class='head'>Gmkg</td>\n\t\t<td class='head'>Flur</td>\n\t\t<td class='head'>Flurst-Nr.</td>\n\t</tr>"
101        ."\n\t<tr>\n\t\t<td title='Gemarkung'>";
102        if ($showkey) {echo "<span class='key'>".$gmkgnr."</span><br>";}
103        echo $gemkname."</td>"
104        . "\n\t\t<td title='Flurnummer'>".$flurnummer."</td>"
105        ."\n\t\t<td title='Flurst&uuml;cksnummer (Z&auml;hler / Nenner)'><span class='wichtig'>".$flstnummer."</span></td>\n\t</tr>"
106        ."\n\t</table>"
107."\n</td>\n<td>"
108."\n\t<p class='nwlink'>weitere Auskunft:<br>";
109
110// Flurstuecksnachweis (o. Eigent.)
111echo "\n\t<a href='alkisfsnw.php?gkz=".$gkz."&amp;gmlid=".$gmlid."&amp;eig=n";
112        if ($showkey) {echo "&amp;showkey=j";}
113        echo "' title='Flurst&uuml;cksnachweis, alle Flurst&uuml;cksdaten'>Flurst&uuml;ck "
114        ."<img src='ico/Flurstueck_Link.png' width='16' height='16' alt=''>"
115."</a><br>";
116
117// FS- u. Eigent.-NW
118echo "\n\t\t<a href='alkisfsnw.php?gkz=".$gkz."&amp;gmlid=".$gmlid."&amp;eig=j";
119        if ($showkey) {echo "&amp;showkey=j";}
120        echo "' title='Flurst&uuml;ck mit Eigent&uuml;mer'>Flurst&uuml;ck mit Eigent&uuml;mer "
121        ."<img src='ico/Flurstueck_Link.png' width='16' height='16' alt=''>"
122."</a><br>";
123
124// FS-Historie
125echo "\n\t\t<a href='alkisfshist.php?gkz=".$gkz."&amp;gmlid=".$gmlid;
126        if ($showkey) {echo "&amp;showkey=j";}
127        echo "' title='Vorg&auml;nger des Flurst&uuml;cks'>Historie "
128        ."<img src='ico/Flurstueck_Historisch.png' width='16' height='16' alt=''>"
129."</a><br>";
130
131// Gebaeude-NW
132echo "\n\t\t<a href='alkisgebaeudenw.php?gkz=".$gkz."&amp;gmlid=".$gmlid;
133        if ($showkey) {echo "&amp;showkey=j";}
134        echo "' title='Geb&auml;udenachweis'>Geb&auml;ude "
135        ."<img src='ico/Haus.png' width='16' height='16' alt=''>"
136."</a>"
137. "\n\t</p>\n</td>";
138
139// Lagebezeichnung MIT Hausnummer (Adresse)
140$sql ="SELECT DISTINCT l.gml_id, s.gml_id AS kgml, l.gemeinde, l.lage, l.hausnummer, s.bezeichnung
141FROM ax_flurstueck f JOIN ax_lagebezeichnungmithausnummer l ON l.gml_id=ANY(f.weistauf)
142LEFT JOIN ax_lagebezeichnungkatalogeintrag s ON l.kreis=s.kreis AND l.gemeinde=s.gemeinde AND l.lage=s.lage
143WHERE f.gml_id= $1 AND f.endet IS NULL AND l.endet IS NULL AND s.endet IS NULL ORDER BY l.gemeinde, l.lage, l.hausnummer;";
144
145$v = array($gmlid);
146$res = pg_prepare("", $sql);
147$res = pg_execute("", $v);
148if (!$res) {
149        echo "\n<p class='err'>Fehler bei Lagebezeichnung mit Hausnummer.</p>";
150        if ($debug > 2) {echo "\n<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
151}
152$j=0;
153while($row = pg_fetch_array($res)) {
154        $sname = htmlentities($row["bezeichnung"], ENT_QUOTES, "UTF-8"); // Str.-Name
155        echo "\n<tr>\n\t"
156                ."\n\t<td class='lr'>".$sname."&nbsp;".$row["hausnummer"]."</td>"
157                ."\n\t<td>\n\t\t<p class='nwlink noprint'>"
158                        ."\n\t\t\t<a title='Lagebezeichnung mit Hausnummer' href='alkislage.php?gkz=".$gkz."&amp;ltyp=m&amp;gmlid=".$row["gml_id"]."'>Lage "
159                        ."<img src='ico/Lage_mit_Haus.png' width='16' height='16' alt=''></a>&nbsp;"
160                        ."\n\t\t\t<a href='alkisstrasse.php?gkz=".$gkz."&amp;gmlid=".$row["kgml"]
161                        ."' title='Stra&szlig;e'>Stra&szlig;e <img src='ico/Strassen.png' width='16' height='16' alt=''></a>"
162                ."\n\t\t</p>\n\t</td>"
163        ."\n</tr>";
164        $j++;
165}
166echo "\n</tr>\n</table>";
167
168// Flurstuecksflaeche
169echo "\n<p class='fsd'>Flurst&uuml;cksfl&auml;che: <b>".$flae."</b></p>";
170
171// *** G R U N D B U C H ***
172echo "\n<h2><img src='ico/Grundbuch_zu.png' width='16' height='16' alt=''> Grundbuch</h2>";
173// ALKIS: FS >istgebucht> GS >istBestandteilVon> GB.
174$sql ="SELECT b.gml_id, b.bezirk, b.buchungsblattnummermitbuchstabenerweiterung as blatt, b.blattart, wa.beschreibung AS blattartv,
175s.gml_id AS s_gml, s.buchungsart, s.laufendenummer, s.zaehler, s.nenner, z.bezeichnung, wb.beschreibung AS bart
176FROM ax_flurstueck f
177JOIN ax_buchungsstelle s ON f.istgebucht=s.gml_id
178JOIN ax_buchungsblatt b ON s.istbestandteilvon=b.gml_id
179LEFT JOIN ax_buchungsblattbezirk z ON z.land=b.land AND z.bezirk=b.bezirk
180LEFT JOIN ax_blattart_buchungsblatt wa ON b.blattart = wa.wert
181LEFT JOIN ax_buchungsart_buchungsstelle wb ON s.buchungsart = wb.wert
182WHERE f.gml_id= $1 AND f.endet IS NULL AND s.endet IS NULL AND b.endet IS NULL AND z.endet IS NULL
183ORDER BY b.bezirk, b.buchungsblattnummermitbuchstabenerweiterung, s.laufendenummer;";
184
185$v = array($gmlid);
186$resg = pg_prepare("", $sql);
187$resg = pg_execute("", $v);
188if (!$resg) {
189        echo "\n<p class='err'>Keine Buchungen.</p>";
190        if ($debug > 2) {echo "\n<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
191}
192
193$j=0; // Z.Blatt
194while($rowg = pg_fetch_array($resg)) {
195        $beznam=$rowg["bezeichnung"];
196        echo "\n<table class='outer'>\n<tr>\n<td>";
197                $blattkey=$rowg["blattart"];
198                $blattart=$rowg["blattartv"];
199                if ($blattkey == 1000) {
200                        echo "\n\t<table class='kennzgb' title='Bestandskennzeichen'>";
201                } else {
202                        echo "\n\t<table class='kennzgbf' title='Bestandskennzeichen'>"; // dotted
203                }
204                        echo "\n\t<tr>"
205                                ."\n\t\t<td class='head'>Bezirk</td>"
206                                ."\n\t\t<td class='head'>".$blattart."</td>"
207                                ."\n\t\t<td class='head'>Lfd-Nr.</td>"
208                                ."\n\t\t<td class='head'>Buchungsart</td>"
209                        ."\n\t</tr>";
210                        echo "\n\t<tr>"
211                                ."\n\t\t<td title='Grundbuchbezirk'>";
212                                        if ($showkey) {echo "<span class='key'>".$rowg["bezirk"]."</span><br>";}
213                                echo $beznam."</td>"
214                                ."\n\t\t<td title='Grundbuch-Blatt'><span class='wichtig'>".$rowg["blatt"]."</span></td>"
215                                ."\n\t\t<td title='Bestandsverzeichnis-Nummer (BVNR, Grundst&uuml;ck)'>".$rowg["laufendenummer"]."</td>"
216                                ."\n\t\t<td title='Buchungsart'>";
217                                        if ($showkey) {echo "<span class='key'>".$rowg["buchungsart"]."</span><br>";}
218                                        echo $rowg["bart"]
219                                ."</td>"
220                        ."\n\t</tr>"
221                ."\n\t</table>";
222
223                if ($rowg["zaehler"] <> "") {
224                        echo "\n<p class='ant'>".$rowg["zaehler"]."/".$rowg["nenner"]."&nbsp;Anteil am Flurst&uuml;ck</p>";
225                }
226                echo "\n</td>\n<td>"
227                ."\n\t<p class='nwlink'>weitere Auskunft:<br>"
228                        ."\n\t\t<a href='alkisbestnw.php?gkz=".$gkz."&amp;gmlid=".$rowg[0];
229                                if ($showkey) {echo "&amp;showkey=j";}
230                                echo "' title='Grundbuchnachweis'>".$blattart." <img src='ico/GBBlatt_link.png' width='16' height='16' alt=''>"
231                        ."</a>"
232                ."\n\t</p>"
233        ."\n</td>\n</tr>\n</table>";
234
235        // E I G E N T U E M E R
236        if ($blattkey == 5000) { // SchlÃŒssel Blatt-Art
237                echo "\n<p>Keine Angaben zum Eigentum bei fiktivem Blatt</p>\n"
238                ."\n<p>Siehe weitere Grundbuchbl&auml;tter mit Rechten an dem fiktiven Blatt.</p>";
239        } else { // kein Eigent. bei fiktiv. Blatt
240                // Ausgabe Name in Function
241                $n = eigentuemer($rowg["gml_id"], false, "imFenster"); // ohne Adressen
242
243                if ($n == 0) { // keine NamNum, kein Eigent.
244                        echo "\n<p class='err'>Keine Eigent&uuml;mer gefunden.</p>"
245                        ."\n<p class='err'>Bezirk ".$rowg["bezirk"]." Blatt ".$rowg["blatt"]." Blattart ".$blattkey." (".$blattart.")</p>";
246                }
247        }
248        $j++;
249}
250if ($j == 0) {echo "\n<p class='err'>Keine Buchungen gefunden.</p>";}
251echo "\n<hr>";
252
253footer($gmlid, $_SERVER['PHP_SELF']."?", "");
254
255?>
256</body>
257</html>
Note: See TracBrowser for help on using the repository browser.